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

 手机用户2502870457 发布于 2022-11-01 00:51

今天遇到个很奇怪的问题,在使用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"

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

谢谢

撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有