如何解决使用 nodejs 的 mysql 模块插入时间值为乱码问题?

今天遇到个很奇怪的问题,在使用mysql的nodejs模块的时候,执行一条插入DateTime值到数据库的语句后,数据库里面添加完成的值显示为乱码,并且会影响后面列值的显示,简化后的代码如下:

var mysql = require('mysql');
var connection = mysql.createConnection({
    host     : '----------',
    user     : '----------',
    password : '----------',
    database : '----------',
    charset : 'utf8'
});
connection.connect();
connection.query('insert into us_thjlgl SET ldsj = NOW()', function(err,res) {
  if (err) throw err;
  console.log(res);
});
connection.end();

此时在数据库里面可以看到刚才添加的时间值为乱码:
图片描述

并且会破坏后续值的数据,执行语句
insert into us_thjlgl SET bjfhm="成都" , ldsj = NOW() , thsj = 100
后,可以在数据库里面发现刚刚插入的三条数据:
图片描述

数据"成都"并没有受影响,数据100被破坏成了另一个值。

数据库的字符集都是utf8,包括代码。字段ldsj 的数据类型为 datetime

mysql模块版本为:"^2.12.0"

网上找了很多答案都不管用。所以到这里来请教下。

谢谢

阅读 3.8k
1 个回答

解决了,因为NOW()的格式为时间戳,需要进行转换后写入,如果想写入当前时间,并且是datetime格式,可以用

db.mysql.raw('FROM_UNIXTIME(' + 要写入的时间戳 + ')')

方法对时间戳进行格式化后,模块就不会以字符串的形式写入数据。

所有代码为:

var field = {
    startTime: db.mysql.raw('FROM_UNIXTIME(' + stTime + ')'),
    endTime: db.mysql.raw('FROM_UNIXTIME(' + endTime + ')')
};
var res = db.conn.query('INSERT INTO tp_schedulelog SET ?', field, function (error, results, fields){});
//可以把SQL打印出来
console.log(res.sql);
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题