java.sql.SQLException: Incorrect decimal value: '' for column 'sys_offset_seq' a

 insert into table values('','admin')
这样写就会报错:



 java.sql.SQLException: Incorrect decimal value: '' for column 'sys_offset_seq' a_第1张图片


这种应该是版本问题,尤其是虚拟主机。
把''改成null不会出错:
insert into log values(null,'admin')
insert into log values(' ','admin')//加个空格

这种问题一般mysql 5.x上出现。我用的mysql5.1,后面查询得知新版本mysql对空值插入有"bug",要在安装mysql的时候去除默认勾选的enable strict SQL mode。如果已经安装好了的,就在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后即可。

 

 

发现以前的程序居然不能正常运行,提示信息如下:
Database error: Invalid SQL: INSERT INTO table(userId,jobId,type,action,startTime,endTime) VALUES(’17′,”,’User’,’Login’,”,’2008-11-23 14:33:56′)
MySQL error: 1366 (Incorrect integer value: ” for column ‘jobId’ at row 1)
Session halted.

第一时间的反应是跟mysql5.0新加的sql-mode有关系,因为前一阵子刚刚看过手册.果然,作了如下更改后就不再提示了.

修改 my.ini 文件.

# Set the SQL mode to strict
sql-mode=”STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION”

改为:

# Set the SQL mode to strict
sql-mode=”NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION”

 

你可能感兴趣的:(mysql,Incorrect,integer,value:,”,for,column,‘jobId’,at,row,1)