专注WEB开发 分享经验,沉淀知识

一个mysql的SQLSTATE[HY000]的错误

 作者:chenxing  时间:2017-09-01 22:39  评论:

对于这样的错误首先先看一下字面上的以上,英语不行的可以用翻译软件看一下,这句话是什么意思:“id字段为‘’值是一个错误的int类型值

先看一个mysql错误,SQLSTATE[HY000]: General error: 1366 Incorrect integer value: '' for column 'id' at row 1。

这是添加数据的接口丢出了这样的一个mysql错误。

对于这样的错误首先先看一下字面上的以上,英语不行的可以用翻译软件看一下,这句话是什么意思:“id字段为‘’值是一个错误的int类型值”。

问题找到了,插入数据类型不一致问题。

问题解决方法:

1.插入正确的类型的数据

id是一个自增id,插入的时候不需要设置id值。我的这个项目报错原因在于,把编辑和添加代码写到一起了,公用了一段插入数据的代码参数,由于添加没有id值,就变空字符了,从而丢出了这样一个错误。这里直接在添加之前unset掉插入数组数据的id项就搞定了。

2.修改mysql配置my.ini

sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"
//将STRICT_TRANS_TABLES这个选项去掉

我们推荐用第一种方式解决,第二张方式虽然把问题解决了,但有点自宫的味道,STRICT_TRANS_TABLES严格的方式操作表,本意是要保护mysql中的数据,直接去了对mysql数据安全是一种威胁。

本身这个问题就是我们自己代码不规范造成的,不管从规范代码还是保护数据前者是最佳选择。

除特别注明外,本站所有文章均为作者原创。 或分享自己的编程经验,或探讨工作中的问题,或聊以人生趣事。 转载请注明出处来自 https://www.qiusuoweb.com/85.html

发布评论

 提交评论
有人回复时邮件通知我

 评论(0)

站长头像
chenxing(PHP攻城狮)

运营天数

总访问量

文章数量

-

-

-

交流群:157451741

新浪微博:草莽兴

 近期文章

聊聊国产化

 2024-08-24 15:56  97

内网穿透工具frp配置详情

 2024-07-18 22:30  192

mac在终端复制出现乱码00~ *** 01~

 2024-07-16 20:38  43

php html生成图片

 2024-07-08 20:25  82

scp命令使用说明

 2024-07-06 12:14  113

如何在当前目录打开终端

 2024-07-04 14:54  84

 最新评论

 tradeOff: 08月30日 10:19
在某些领域国产化是一个迫不得已的事儿
来源: 聊聊国产化
 sue: 07月03日 10:24
可以
来源: 微信小程序如何获取单个input值
 流年: 07月02日 11:31
不错的尝试
来源: 博客系统如何用markdown编辑器发布文章
 诚心: 09月29日 23:01
学到了
来源: 如何一次性推送百万级别的消息
 Nick: 04月14日 12:26
网上的资料还是太老,都只是取一个元素,解决了一大难题
来源: redis set集合取出一组数据并删除
 skywalker: 11月03日 18:21
简洁明了
来源: mysql 获取某个日期的前一天或后一天