最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

MySQL模式:StrictMode_MySQL

来源:懂视网 责编:小采 时间:2020-11-09 18:49:16
文档

MySQL模式:StrictMode_MySQL

MySQL模式:StrictMode_MySQL:bitsCN.com 刚刚在配置阿里云主机的环境:IIS7.5+PHP5.3+MySQL5.5安装Mysql过程中遇到Strict Mode的选项,特意料了解了一下,大致如下: 一. Strict Mode的描述:根据 mysql5.0以上版本 strict mode (STRICT_TRANS_TABLES)
推荐度:
导读MySQL模式:StrictMode_MySQL:bitsCN.com 刚刚在配置阿里云主机的环境:IIS7.5+PHP5.3+MySQL5.5安装Mysql过程中遇到Strict Mode的选项,特意料了解了一下,大致如下: 一. Strict Mode的描述:根据 mysql5.0以上版本 strict mode (STRICT_TRANS_TABLES)

bitsCN.com 刚刚在配置阿里云主机的环境:IIS7.5+PHP5.3+MySQL5.5

安装Mysql过程中遇到Strict Mode的选项,特意料了解了一下,大致如下:

一. Strict Mode的描述:
根据 mysql5.0以上版本 strict mode (STRICT_TRANS_TABLES) 的限制:
1).不支持对not null字段插入null值
2).不支持对自增长字段插入''值,可插入null值
3).不支持 text 字段有默认值
eg:
1.看下面代码:(第一个字段为自增字段)
$query="insert into demo values('','$firstname','$lastname','$sex')";
上边代码只在非strict模式有效,如果是strict模式下就会出错。

2.$query="insert into demo values(NULL,'$firstname','$lastname','$sex')";
上边代码只在strict模式有效。把空值''换成了NULL.

二. 让数据库支持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.ini,关闭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 = ''");

如果安装过程中选择了Strict Mode,如何关闭呢?也专门找了下方法,我建议安装时还是不要选择了!

关闭MySQL的strict mode的具体做法:找到MySQL目录下的my.ini,将其中的sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION" 修改为sql-mode="NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION",重新启动 Mysql服务

bitsCN.com

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

MySQL模式:StrictMode_MySQL

MySQL模式:StrictMode_MySQL:bitsCN.com 刚刚在配置阿里云主机的环境:IIS7.5+PHP5.3+MySQL5.5安装Mysql过程中遇到Strict Mode的选项,特意料了解了一下,大致如下: 一. Strict Mode的描述:根据 mysql5.0以上版本 strict mode (STRICT_TRANS_TABLES)
推荐度:
标签: 模式 主机 mysql
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top