加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 黄冈站长网 (http://www.0713zz.com/)- 数据应用、建站、人体识别、智能机器人、语音技术!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MySQL模式 Strict Mode知识点解说

发布时间:2022-03-04 18:27:19 所属栏目:MySql教程 来源:互联网
导读:MySQL模式 Strict Mode知识点解说: I. Strict Mode阐述 根据 mysql5.0以上版本 strict mode (STRICT_TRANS_TABLES) 的限制: 1).不支持对not null字段插入null值 2).不支持对自增长字段插入值,可插入null值 3).不支持 text 字段有默认值 看下面代码:(第
       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知识点详解的文章就介绍到这了。

(编辑:PHP编程网 - 黄冈站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读