gpt4 book ai didi

MySQL模式 Strict Mode知识点详解

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章MySQL模式 Strict Mode知识点详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

I. Strict Mode阐述 。

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

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

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

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

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

Sql代码 。

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

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

Code代码 。

?
1
$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

?
1
sql-mode="NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"

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

?
1
2
3
if ($this->dbcharset) {
@mysql_query("SET NAMES ".$this->dbcharset);
}

后面执行 。

?
1
mysql_query("SET @@sql_mode = ''");

注意确定你使用的是MySQL5 。

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

?
1
mysqli_query($this->connection_id, "SET @@sql_mode = ''");

到此这篇关于MySQL模式 Strict Mode知识点详解的文章就介绍到这了,更多相关MySQL模式 Strict Mode内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。

原文链接:https://www.iteye.com/blog/koda-288882 。

最后此篇关于MySQL模式 Strict Mode知识点详解的文章就讲到这里了,如果你想了解更多关于MySQL模式 Strict Mode知识点详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com