javascript - 等待它解析promise,然后插入MySQL

标签 javascript mysql node.js wordpress

我在 Nodejs 中有代码,它将首先插入一个帖子,然后插入一个元帖子(其他表)。

我希望先插入帖子,然后搜索最后一个 ID 并插入元帖子(其他表)。

但是它不起作用,似乎它没有等待第一个函数插入帖子。

这是我的代码:

function insertarpost() { 
    return new Promise(function(resolve, reject) { 
        var sql = "INSERT INTO `wp_posts` ( `post_author`, `post_date`, `post_date_gmt`, `post_content`, `post_title`,`post_excerpt`, `post_status`,`comment_status`, `ping_status`,`post_password`, `post_name`,`to_ping`,`pinged`, `post_modified`, `post_modified_gmt`,`post_content_filtered`,`post_parent`, `guid`,`menu_order`, `post_type`, `post_mime_type`,`comment_count`) VALUES (1, '"+fhoy+"', '"+fhoy+"', ' ', '"+title+"','', 'publish', 'open', 'closed','','"+slug+"','','', '"+fhoy+"', '"+fhoy+"','', '0','','0', 'movies','' ,0);"; 
        con.query(sql, function (err, result) { 
            if (err) throw err; 
            resolve(result); 
            console.log("1 registro insertado"); 
        }); 
    }); 
}

insertarpost().then(obtenerultimopostid())

function obtenerultimopostid() {
    con.query("SELECT ID FROM wp_posts ORDER BY ID DESC LIMIT 0,1;", function (err, result, fields) {
        var sql = "INSERT INTO wp_postmeta (post_id, meta_key, meta_value) VALUES ("+result[0].ID+",'runtime', '"+runtime+"'),("+result[0].ID+",'original_title','"+titleoriginal+"'),("+result[0].ID+",'Rated','"+cpgrated+"'),("+result[0].ID+",'Country', '"+country+"'),("+result[0].ID+",'date', '"+datemovie+"'),("+result[0].ID+",'imdbRating', '"+repimdb+"'),("+result[0].ID+",'vote_average', '"+reptmdb+"'),("+result[0].ID+",'imdbVotes', '"+quantimdb+"'),("+result[0].ID+",'vote_count', '"+quanttmdb+"'),("+result[0].ID+",'tagline', '"+tagline+"'),("+result[0].ID+",'dt_poster', '"+poster+"');"; 
        con.query(sql, function (err, result) { 
            if (err) throw err; 
            console.log("1 registro wpmeta insertado");
        });
    });
}

最佳答案

您正在立即执行第二个函数,而不是函数传递给then方法:

更改:

insertarpost().then(obtenerultimopostid())

至:

insertarpost().then(obtenerultimopostid)

不是你的问题,但你的代码容易受到 SQL injection 的攻击.

关于javascript - 等待它解析promise,然后插入MySQL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60684250/

相关文章:

javascript - AngularJS: array[ {{value}} ] 导致我想忽略的解析错误

java - 在指向另一个PreparedStatement 之前是否有必要关闭PreparedStatement?

mysql - 如何在同一列中选择满足2个条件的项目

mongodb - Mongoose 唯一索引不起作用!

javascript - 浏览器实现的 'new Image()' 替代方案是 node-webgl javascript 实现?

javascript - 数组上的 $gte 和 $lte

javascript - 在打开新标签页时触发 Chrome 扩展程序

javascript - Django:将 textarea 小部件与 javascript 字符计数器/限制器一起使用?

php - sql查询只返回一行

javascript - 从项目中的任何地方获取 socket.io 命名空间