Navicat运⾏SQL⽂件出错
错误如下:
[ERR] 1292 - Incorrect datetime value: '0000-00-00 00:00:00' for column 'create_at' at row 1
[ERR] 1050 - Table 'a***ny_info' already exists
[ERR] 1062 - Duplicate entry '209' for key 'PRIMARY'
[SQL] Finished with error
解决步骤办法:
1.在MySQL的bin⽬录下 mysql -h localhost -u root -p ,连接数据库
2.select @@sql_mode; 查看权限,可以看到有NO_ZERO_IN_DATE,NO_ZERO_DATE
⽐如我的就是
3.去除NO_ZERO_IN_DATE,NO_ZERO_DATE,设置sql_mode的值为
ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
4.重启MySQL,然后连接数据库查看
select @@sql_mode;
没有NO_ZERO_IN_DATE,NO_ZERO_DATE,
Navicat运⾏线上转储的SQL⽂件成功
备注(可不看,只做记录):
贴个图做记录
图1
图2接图1
图3接图2数据库管理系统的主要功能是
图4接图3
参考来源:
1.MySQL运⾏存储过程出现1292错误
在navicat上远程连接MySQL,运⾏存储过程时传⼊了⼀个时间参数‘0000-00-00 00:00:00’,发⽣如下错误
1292 - Incorrect datetime value: '0000-00-00 00:00:00' for column 'targetTime' at row 1
官⽅⽂档上说明MySQL允许将’0000-00-00’保存为“伪⽇期”,但是MySQL有⼀个NO_ZERO_DATE SQL模式,这个模式默认是打开的,不允许产⽣伪⽇期,所以要关掉这个选项。执⾏SQL语句:
set global
sql_mode='STRICT_TRANS_TABLES,STRICT_ALL_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER';
使⽤show variables like '%sql_mode%';查看关于sql_mode的变量,如果没有NO_ZERO_IN_DATE和NO_ZERO_DATE就说明修改成功
---恢复内容开始---
摘要: mysql5.7版本相⽐较之前的版本有很多的特性的增加以及默认配置的改变,在使⽤中难免会遇到与之前的使⽤习惯或者项⽬需求不符的情况。就需要调整相应的变量的值,⽐如sql_mode的值
最近在做⼀个项⽬的迁移⼯作,由于开发环境所使⽤的都是最新的软件版本(mysql5.7)。迁移时难免会遇到⼀些兼容性的“坑”,⽐如oracle中的数据迁移到mysql中的时间问题:
mysql中的时间问题:
将oracle
设计到类似这样的表结构:
范围随机数公式
CREATETABLE `cm_admin_user_group` (
`id` int(11)NOTNULL AUTO_INCREMENT,
`user_id`int(11)NOTNULLDEFAULT'0'COMMENT'User ID',
`group_id` int(11)NOTNULLDEFAULT'0'COMMENT'Group ID',
`is_leader` int(1)NOTNULLDEFAULT'0'COMMENT'是否组长;0:不是,1:是',
`updated_at` timestampNOTNULLDEFAULTCURRENT_TIMESTAMPONUPDATECURRENT_TIMESTAMPCOMMENT'更新时间',
`created_at` timestampNOTNULLDEFAULT'0000-00-00 00:00:00'COMMENT'加⼊时间',
PRIMARYKEY (`id`),
UNIQUEKEY`uidx` (`user_id`,`group_id`)
) ENGINE=InnoDB AUTO_INCREMENT=12DEFAULTCHARSET=utf8;
1<code class="hljs sql"><span class="hljs-keyword"><span class="hljs-keyword"> </span></span></code>
timestamp  并且会默认零⽇期(业务设计需求),但是在mysql5.7的版本中,默认是不允许created_at 的类型是timestamp
updated_at 和created_at
其中的updated_at
设置为零⽇期的。为此,需要更改mysql的配置⽂件。
⾸先,查看当前的mysql中的 sql_mode变量的值:
#select@@sql_mode;
mysql>select@@sql_mode;
+----------------------------------------------------------------------------------------------------------------------------------------------------------------+
计算机进制转换公式|@@sql_mode|
+----------------------------------------------------------------------------------------------------------------------------------------------------------------+
|PIPES_AS_CONCAT,ANSI_QUOTES,ONLY_FULL_GROUP_BY,NO_AUTO_VALUE_ON_ZERO,STRICT_TRANS_TABLES,ERROR_FOR_ DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION|
+----------------------------------------------------------------------------------------------------------------------------------------------------------------+
1rowinset(0.00sec)
1<code class="hljs lua"> </code>
限制字段不能为零⽇期
默认会有:NO_ZERO_IN_DATE
NO_ZERO_IN_DATE和 NO_ZERO_DATE 两个值,限制字段不能为零⽇期
mysql语句的执行顺序编写网页代码更改配置⽂件,去掉这两个值即可。
vim/etc/myf
1<code class="hljs nginx"><span class="hljs-attribute"><span class="hljs-attribute"> </span></span></code>
增加⼀⾏:
sql_mode=NO_AUTO_VALUE_ON_ZERO,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO _ENGINE_SUBSTITUTION,PIPES_AS_CONCAT,ANSI_QUOTES
1<code class="hljs ini"><span class="hljs-attr"><span class="hljs-attr"> </span></span></code>
其他的则根据场景和业务⾃⾏更改。
转:
3.MySQL修改sql_mode
java开发转运维容易吗

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。