当前位置: 移动技术网 > IT编程>数据库>Mysql > MySQL模式 Strict Mode知识点详解

MySQL模式 Strict Mode知识点详解

2020年05月12日  | 移动技术网IT编程  | 我要评论

twice组合,德州一中招聘,落水狗qvod

i. strict mode阐述

根据 mysql5.0以上版本 strict mode (strict_trans_tables) 的限制:

1).不支持对not null字段插入null值

2).不支持对自增长字段插入''值,可插入null值

3).不支持 text 字段有默认值

看下面代码:(第一个字段为自增字段)

sql代码

$query="insert into demo values('','$firstname','$lastname','$sex')"; 

上边代码只在非strict模式有效。

code代码

$query="insert into demo values(null,'$firstname','$lastname','$sex')"; 

上边代码只在strict模式有效。把空值''换成了null.

ii.让数据库支持strict mode

1.对数据库结构进行以下改进来支持strict mode:

1) 给所有not null字段都设置非null默认值,字符串默认值为 '',数值默认值为 0,日期默认值为 '0000-00-00 00:00:00'

2) 去掉text字段的默认值

3) 规范化改进: 把 title 字段统一改为 varchar(255),把有默认值的null字段改为not null字段

2.如果安装的php程序数据库结构关闭strict mode

1).一个是安装mysql5.0(含以上)版本的时候去掉strict mode。

编辑 my.cnf,关闭strict mode:

sql-mode="no_auto_create_user,no_engine_substitution"

2). 另一个就是修改查询语句。例如在

if ($this->dbcharset) {
@mysql_query("set names ".$this->dbcharset);
}

后面执行

mysql_query("set @@sql_mode = ''");

注意确定你使用的是mysql5

mysqli方式类似,就是执行的是

mysqli_query($this->connection_id, "set @@sql_mode = ''");

到此这篇关于mysql模式 strict mode知识点详解的文章就介绍到这了,更多相关mysql模式 strict mode内容请搜索移动技术网以前的文章或继续浏览下面的相关文章希望大家以后多多支持移动技术网!

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网