MySQL模式 Strict Mode知识点详解
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内容请搜索好吧啦网以前的文章或继续浏览下面的相关文章希望大家以后多多支持好吧啦网!
相关文章:
1. MySQL存储过程例子(包含事务、参数、嵌套调用、游标循环等)2. MySQL全文搜索之布尔搜索3. Mysql入门系列:在MYSQL结果集上执行计算4. Windows下在DOS用mysql命令行导入.sql文件5. Mysql入门系列:需要避免的MYSQL客户机程序设计错误6. Mysql入门系列:MYSQL表达式求值和MYSQL类型转换7. mybatis plus in方法使用详解8. Mysql入门系列:MYSQL列类型选择与MYSQL查询效率9. Mysql入门系列:安排预防性的维护MYSQL数据库服务器10. Mysql故障排除:Starting MySQL. ERROR! Manager of pid-file quit without updating file

网公网安备