疯狂编程网

  • 首页
  • 后端
    • GOLANG
    • PHP
  • 前端
  • 客户端
  • 服务器
  • AIGC
  • 开发工具
  • 代码人生
  • 关于本站
    • 联系我们
    • 免责声明
  1. 首页
  2. 服务器
  3. MYSQL
  4. 正文

Mysql 插入timestamp没有使用默认值问题

2023年5月10日 307点热度 0人点赞 0条评论

在一次升级过程中,发现Mysql插入数据报了个错

Column 'create_time' cannot be null.

但是看了下这个字段虽然是非null,但是是有默认值的

`create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP

报这个错的原因是往这个字段里插入了null,但是没有用默认值代替null

看了下本地和服务器的Mysql版本都是5.7,在本地是没有问题的

最后发现是有一个explicit_defaults_for_timestamp参数去控制timestamp的列的默认值还是NULL

show variables like 'explicit_defaults_for_timestamp';

这个参数默认为off

当设置为off时:

如果往这个列中插入null值,会自动的设置该列的值为current timestamp值

当设置为on时:

此时向该列中插入null值时,会直接记录null,而不是current timestamp

修改参数可以使用set或者修改my.cnf配置,set重启会失效

//改成off
set GLOBAL explicit_defaults_for_timestamp = 1

参考:https://segmentfault.com/a/1190000018818020

本文来自博客园,作者:阿弱,转载请注明原文链接:https://www.cnblogs.com/aruo/p/16778676.html

标签: mysql
最后更新:2023年5月10日

大明

靠写代码养家的开发者。

点赞
< 上一篇
下一篇 >

文章评论

razz evil exclaim smile redface biggrin eek confused idea lol mad twisted rolleyes wink cool arrow neutral cry mrgreen drooling persevering
取消回复

COPYRIGHT © 2023 疯狂编程网. ALL RIGHTS RESERVED.

京ICP备2022013580号-1