MySQL模式 Strict Mode知识点详解
程序员文章站
2022-05-01 21:06:36
i. strict mode阐述根据 mysql5.0以上版本 strict mode (strict_trans_tables) 的限制:1).不支持对not null字段插入null值2).不支持...
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内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
推荐阅读
-
在JavaScript中使用严格模式(Strict Mode)
-
mysql中的sql_mode模式实例详解
-
MySQL中SQL Mode的查看与设置详解
-
MySQL的sql_mode模式修改my.cnf
-
mysql: [ERROR] unknown variable ‘sql-mode=STRICT_ALL_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ZERO_DATE,
-
mysql 严格模式 Strict Mode说明(text 字段不能加默认或者 不能加null值得修改方法)
-
Javascript 严格模式use strict详解
-
mysql MGR 单主多主模式切换知识点详解
-
详解Android Automotive车载应用对驾驶模式Safe Drive Mode的适配
-
MySQL中slave_exec_mode参数详解