视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
node.js的mysql模块query方法里的字符串拼接问题
2020-11-09 16:56:11 责编:小采
文档


mysqlnode.jsquery

我写了一个和mysql交互的Node.js。大致功能是,在浏览器端提交用户信息表单后,会在现有的表userInfo里插入一条用户记录;然后针对这条用户记录自动再生成一个表,该表的名称是根据这条记录的id动态生成的。

该部分我写的代码如下:

 //上面的代码已经实现把一条新的用户记录插入到userInfo里了。 var userId; var tableName; db.query(//这里通过query方法获取这条新记录的id(因为id是自动自增生成的) "SELECT user_id FROM userInfo "+ "WHERE identity=?", [dataObj.identity], function (err,rows) { if (err) { throw err; } else{ userId=rows[0].user_id;//获取的userId假设为0 console.log(userId); tableName='user_'+userId;//tableName变量装入要生成的新表的名称'user_0' console.log(tableName);//(1) } } ); //(2) db.query( 'CREATE TABLE IF NOT EXISTS '+tableName+//创建新表的时候表名使用tableName变量的内容'user_0' '(arti_id INT NOT NULL AUTO_INCREMENT PRIMARY KEY, '+ 'title VARCHAR(50) NOT NULL, '+ 'maintext LONGTEXT, '+ 'time TIMESTAMP)', function (err) { if (err) { throw err; } else{ console.log("New user's article table has successfully created.") } } );

运行成功,但是查看数据库,这张新表并不叫 user _0, 而是叫undefine。

现检查结果如下:
通过上述(1)语句可以看到装入表名的变量tableName确实是user_0.
所有语句不变,把tableName直接赋值为‘user_0’的话(即在(2)处加入tableName='user_0'),得到的新表表名就是user_0了。

请问为什么会这样呢?我一定要通过动态获取id再给tableName赋值,怎样才能实现正确结果呢?

下载本文
显示全文
专题