关于MySQL数据库因版本不一致数据传输失败那些事之报错1067 – Invalid default value for ‘字段名’

        之前在工作的时候,在自己的服务器上部署了工作室的项目方便在线下进行模拟调试修复Bug。但是在将工作室数据库数据传输到我自己的服务器时却报了个错,1067 – Invalid default value for ‘字段名’。仔细看原来工作室的数据库版本是5.6的,我服务器本地的版本是5.7。所以导致有些数据不兼容,我那时候报的错是Invalid default value for 'createTime',是时间字段,类型是datetime。然后就想到可能是时间类型的默认值被限制了,然后我就去查看 sql_mode。果然:NO_ZERO_IN_DATE,NO_ZERO_DATE这两个参数被限制不能为0。

        进入到MySQL命令行操作界面

 

查看sql_mode

        会话级别

select @@session.sql_mode;

        全局级别

select @@global.sql_mode;

修改sql_mode

        临时修改

        该级别为会话级别的修改,session均可省略,默认session,仅对当前会话有效

set @@session.sql_mode='ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';

set session sql_mode='ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';

        该级别为全局级别的修改,但也是临时修改,需高级权限,仅对下次连接生效,不影响当前会话,且MySQL重启后失效。因为MySQL重启时会重新读取配置文件里对应值,如果需永久生效需要修改配置文件里的值。

set global sql_mode='STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
set @@global sql_mode='STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';

        永久修改

        打开my.ini文件,找到以下语句

sql-mode = "xx_mode"

        替换为以下,如果找不到就在空白处新加

sql-mode ='STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'

        新加完后重启MySQL服务即可,重新进行数据传输此时便不会报错

        各位看官老爷,收藏起来呗,万一以后用得到呢,再不行点个赞再走/(ㄒoㄒ)/~~

        (以上内容仅供学习参考,若有错误之处欢迎指正交流)

  • 6
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
### 回答1: 1067-invalid default value for是MySQL数据库中的错误提示,通常是由于在创建表时指定了无效的默认值导致的。这个错误提示通常会出现在MySQL版本升级后,因为新版本中默认值的规则可能会有所改变。要解决这个问题,可以检查表结构中的默认值是否符合MySQL的规则,或者修改MySQL的配置文件以允许使用旧版本的默认值规则。 ### 回答2: 1067-invalid default value for是MySQL数据库报出的错误提示,主要是由于在创建表格时指定了无效的默认值所引起。 当我们在创建数据表的时候,可能会在某一列中指定一个默认值。如果该默认值被识别为无效,则会出现1067错误。这个错误通常发生在MySQL版本更新后,因为MySQL版本升级后,数据类型的默认值有很多变化。 解决1067-invalid default value for这个错误很简单,具体命令如下: 1. 首先,你需要登录MySQL数据库,并进入你的数据库。 2. 执行命令:SET sql_mode = ''; 这个命令意思是设置当前MySQL的sql模式为默认值,这样就可以解决1067错误了。 3. 然后执行 CREATE TABLE 命令,即可成功创建数据表。 4. 如果你的MySQL版本较高,则可以使用以下命令: SET sql_mode = 'NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'; 以上命令便可以很好地解决1067-invalid default value for错误。 总之,当我们在使用MySQL数据库时,必须注意设置数据类型的默认值,否则就会出现1067错误。当出现这种错误时,可以通过设置MySQL的sql模式来解决问题。此外,在MySQL数据库的使用中,更要注意版本更新,因为版本更新也可能导致数据类型的默认值发生变化。 ### 回答3: 1067-invalid default value for是什么意思? 1067-invalid default value for是MySQL数据库中的一个错误提示信息。这个错误通常是在向数据库中插入数据时出现的,该数据包含一个无效的默认值。这个错误通常会导致数据插入失败,因此需要修复。 该错误原因很多,可能是因为在插入数据时设置了一个不存在的默认值,或者是设置了一个格式错误的默认值,还有可能是设置了不支持的默认值类型等。因此,如果出现了1067-invalid default value for错误,就需要仔细检查并确定数据中是否存在无效的默认值,然后进行修正。 如何解决1067-invalid default value for错误? 要解决1067-invalid default value for错误,需要按照以下步骤进行检查和修正: 1. 检查数据表中的默认值,确定是否存在格式错误或不支持的默认值类型。 2. 检查数据库版本和编码设置是否正确,可能会因为版本不同或编码不匹配导致该错误。 3. 确定具体出现错误的位置,查找是哪一个字段出现了无效的默认值。这个过程可以通过MySQL提供的一些工具来完成,例如SHOW CREATE TABLE、DESC和EXPLAIN等命令。 4. 如果发现数据表中设置了无效的默认值,则需要修改相应字段的默认值设置,或者完全删除这个无效的默认值,然后重新插入数据。 综上所述,1067-invalid default value for错误是一个比较常见的MySQL数据库错误,出现了这个错误就需要仔细排查和修正,以确保数据表中的默认值正确有效。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

第一天才

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值