最近自己在测试一个开源的程序,测试中发现。该程序都添加和更新的时候回出现 Incorrect integer value: '' for column 'id' at row 1类是的错误!
后来我自己测试了一下:
insert into log values('','admin','31','002t')
这样写就会报错: Incorrect integer value: '' for column 'id' at row 1
一般我们是认为应该没错误的。后来查了下MYSQL的资料。发现5以上的版本如果是空值应该要写NULL
这种问题一般mysql 5.x上出现。我用的mysql5.1
官方解释说:得知新版本mysql对空值插入有"bug",要在安装mysql的时候去除默认勾选的enable strict SQL mode
那么如果我们安装好了mysql怎么办了,解决办法是更改mysql中的配置 my.ini
my.ini中查找sql-mode, 默认为sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION", 将其修改为sql-mode="NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION",重启mysql后即可
|
那么如果是虚拟主机或者是空间怎么办了。如果你能让空间商帮你改那是最好。如果不能,那你就只能程序改改。都规范一点。空值就写 null
其实最后的结果是表没建成功,我后来是换了一软件可以了
未来星开发团队--狒狒QQ:9715234继续阅读与本文标签相同的文章
上一篇 :
MySQL中的MVCC概念介绍(1)
-
20160120使用myeclipse一年开始转IntelliJ IDEA 15做以下总结
2026-05-26栏目: 教程
-
三张照片解决--win10系统的edge浏览器设置为浏览器IE8,IE7,IE9---完美解决 费元星
2026-05-26栏目: 教程
-
java获取当前路径的几种方法
2026-05-26栏目: 教程
-
Myeclipse报错-Java compiler level does not match 完美解决方法
2026-05-26栏目: 教程
-
java lambda 深入浅出
2026-05-26栏目: 教程
