网站搬家之mysql 5.7 date类型默认值不能设置‘0000-00-00’的问题
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了网站搬家之mysql 5.7 date类型默认值不能设置‘0000-00-00’的问题,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1922字,纯文字阅读大概需要3分钟。
内容图文
![网站搬家之mysql 5.7 date类型默认值不能设置‘0000-00-00’的问题](/upload/InfoBanner/zyjiaocheng/485/32ef905cbfa24cf2b8fb6220d0765cc3.jpg)
查阅手册
The DATE type is used for values with a date part but no time part. MySQL retrieves and displays DATE values in ‘YYYY-MM-DD‘ format.
The supported range is ‘1000-01-01‘ to ‘9999-12-31‘.
mysql 5.7使用NO_ZERO_IN_DATE, NO_ZERO_DATE两个选项,禁止了0000这样的日期和时间,理想的解决办法:
将日期、时间格式改成 ‘1000-01-01‘ 到 ‘9999-12-31‘之间即可
而我是利用导入导出SQL文件来搬家,批量替换有点麻烦,一种不推荐方法,在mysql的配置文件中,重新设置sql_mode,去掉这两项就可以了。
linux:
修改my.cnf文件,重启mysql。
Mac:
在MacOS中默认是没有my.cnf 文件,如果需要对MySql 进行定制,拷贝/usr/local/mysql/support-files/目录中任意一个.cnf 文件。将它放到其他目录,按照上面修改完毕之后,更名为my.cnf,然后拷贝到/etc目录再重启下mysql就大功告成了。
Windows:
修改my.ini文件后重启mysql。
在[mysqld]中添加 sql-mode=ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO
查看sql-mode的方法:
mysql数据库的中有一个环境变量sql_mode,定义了mysql应该支持的sql语法,数据校验等
mysql> select @@sql_mode; +----------------------------------------------------------------+ | @@sql_mode | +----------------------------------------------------------------+ | STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION | +----------------------------------------------------------------+
查看系统变量
mysql> show variables like ‘sql_mode%‘\G; *************************** 1. row *************************** Variable_name: sql_mode Value: STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
网站搬家之mysql 5.7 date类型默认值不能设置‘0000-00-00’的问题
标签:ret local 日期 my.cnf 目录 不能 engine 选项 weight
本文系统来源:http://www.cnblogs.com/eDevelop/p/7081061.html
内容总结
以上是互联网集市为您收集整理的网站搬家之mysql 5.7 date类型默认值不能设置‘0000-00-00’的问题全部内容,希望文章能够帮你解决网站搬家之mysql 5.7 date类型默认值不能设置‘0000-00-00’的问题所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。