注册用户享全站资源 并成为粉丝 不定时福利发放
 

mysql的set sql_mode作用

3
发表时间:2018-11-30 11:07

摘要:之前没有接触过mysql的sql_mode的知识,只是遇到过我的cms在我本地和我的服务器上是好好的,然后有的人在用的时候,如果插入的数据过...

之前没有接触过mysql的sql_mode的知识,只是遇到过我的cms在我本地和我的服务器上是好好的,然后有的人在用的时候,如果插入的数据过长的话会报错,我一直不知怎么解决,今天终于知道了。原来都是SQL_MODE设置的原因。

SQL_MODE默认为空,可以在MySQL的配置文件如my.cnf和my.ini中进行修改,也可以在客户端工具中或者命令来进行修改。

查询当前SQL_MODE设置:

SELECT @@global.sql_mode;

SQL_MODE的常见模式:

STRICT_TRANS_TABLES :在该模式下,如果一个值不能插入到一个事务表(例如表的存储引擎为InnoDB)中,则中断当前的操作不影响非事务表(例如表的存储引擎为MyISAM)。

ALLOW_INVALID_DATES :该选项并不完全对日期的合法性进行检查,只检查月份是否在1~12之间,日期是否在1~31之间。该模式仅对DATE和DATETIME类型有效,而对TIMESTAMP无效,因为TIMESTAMP总是要求一个合法的输入。

ANSI_QUOTES :启用ANSI_QUOTES后,不能用双引号来引用字符串,因为它将被解释为识别符。

ERROR_FOR_DIVISION_BY_ZERO :在INSERT或UPDATE过程中,如果数据被零除(或MOD(X,0)),则产生错误(否则为警告)。如果未给出该模式,那么数据被零除时MySQL返回NULL。如果用到INSERT IGNORE或UPDATE IGNORE中,MySQL生成被零除警告,但操作结果为NULL。

严格模式是指将SQL_MODE变量设置为 STRICT_TRANS_TABLES 或 STRICT_ALL_TABLES 中的至少一种。

在SQL_MODE设置为空的情况下,mysql执行的是一种不严格的检查,例如日期字段可以插入'0000-00-00 00:00:00'这样的值,还有如果要插入的字段长度超过列定义的长度,那么mysql不会终止操作,而是会自动截断后面的字符继续插入操作。

既然知道了这些,那就可以加入以下设置:

如果mysql版本大于 5.0的话,在php连接mysql的时候会用如下语句

if ($serverinfo > '5.0') { 
	mysqli_query($this->sql, "SET sql_mode=''");
}

这样一来,就可以防止用户误操作,把定义的字段写的过多而报错的情况了。


会员登录

会员登录

登录免费下载全站资源

获取验证码
登录
登录
开发简历

开发简历

简历模板网站自取

入坑需谨慎

入坑需谨慎

高薪完全靠自己

微信赞助-Java帮帮社区

微信赞助-Java帮帮社区

非盈利性学习社区

支付宝赞助-Java帮帮社区

支付宝赞助-Java帮帮社区

将分享做到极致

大公司资讯
文章附图

近日,在美国推出满一年的Facebook视频服务Watch,宣布正式向全球推广,这预示着视频领域中,YouTube...

文章附图

据彭博社北京时间9月19日报道,科技行业最引人注目的法律大战可能正在进入尾声。据高通CEO史蒂夫·莫伦科夫(Ste...

Java帮帮公众号生态

Java帮帮公众号生态

总有一款适合你

Java帮帮-微信公众号

Java帮帮-微信公众号

将分享做到极致

Python帮帮-公众号

Python帮帮-公众号

人工智能,爬虫,学习教程

大数据驿站-微信公众号

大数据驿站-微信公众号

一起在数据中成长

九点编程-公众号

九点编程-公众号

深夜九点学编程

程序员服务区-公众号

程序员服务区-公众号

吃喝玩乐,听学吐画

Java帮帮学习群生态

Java帮帮学习群生态

总有一款能帮到你

Java学习群

Java学习群

与大牛一起交流

大数据学习群

大数据学习群

在数据中成长

九点编程学习群

九点编程学习群

深夜九点学编程

python学习群

python学习群

人工智能,爬虫

测试学习群

测试学习群

感受测试的魅力

Java帮帮生态承诺

Java帮帮生态承诺

一直坚守,不负重望

初心
勤俭
诚信
正义
分享
合作品牌 非盈利生态-优质内容分享传播者
关于我们
友链申请
友链交换:加帮主QQ2524138991 留言即可 24小时内答复  
全站内容非商业用途,内容来源于网友,并遵循 CC BY-NC 4.0 许可,如有异议请联系客服。
会员登录
获取验证码
登录
登录
我的资料
留言
回到顶部