MySQL 严格模式 sql_mode

虽然说我们尽量在写程序的时候控制插入到数据库的数据,而不要用数据库去判断数据的对错,但是有时候为了方便还是需要数据库自身的容错能力来帮助我们达到目的的。举例说明:

 

创建如下数据表

CREATE TABLE `book` (
  `id` int(11) default NULL,
  `num` int(11) unsigned default NULL
) ENGINE=InnoDB DEFAULT CHARSET=gbk
 
insert into bookvalues(1,0),(2,0)
 


执行update book set num='abc',竟然不报错,原因是没有启用严格模式。所以

先执行set sql_mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION",

然后执行update book set num='abc',数据库就报错了

 

如果想一劳永逸,那就直接把数据库配置文件my.ini中的相关参数设置为

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

你可能感兴趣的:(sql,数据库,mysql,user,null,insert)