主页 > 知识库 > MySQL模式 Strict Mode知识点详解

MySQL模式 Strict Mode知识点详解

热门标签:郑州网络外呼系统价钱 电话机器人是电脑呼号吗 机器人打电销电话 南宁外呼系统招商 400电话到哪办理优惠 怎么更改高德地图标注 云南大数据外呼系统 上海市三维地图标注 博乐电销机器人

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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
  • mysql中的sql_mode模式实例详解
  • Django2 连接MySQL及model测试实例分析
  • 关于MySQL的sql_mode合理设置详解
  • MySQL关于sql_mode解析与设置讲解
  • MySQL中SQL Mode的查看与设置详解

标签:秦皇岛 杭州 白银 定西 澳门 宁夏 恩施 益阳

巨人网络通讯声明:本文标题《MySQL模式 Strict Mode知识点详解》,本文关键词  MySQL,模式,Strict,Mode,知识点,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《MySQL模式 Strict Mode知识点详解》相关的同类信息!
  • 本页收集关于MySQL模式 Strict Mode知识点详解的相关信息资讯供网民参考!
  • 推荐文章