zoukankan      html  css  js  c++  java
  • 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: 
    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 = ''"); 

  • 相关阅读:
    在 Tomcat 8 部署多端口项目
    tar -zxvf jdk-8u144-linux-x64.tar.gz
    linux下删除文件夹的命令
    springboot+mybatis案例
    阿里云主机密码
    查看公钥
    jenkins安装
    redis详解(包含使用场景)
    什么是JSONP?
    在CentOS7上面搭建GitLab服务器
  • 原文地址:https://www.cnblogs.com/gaohj/p/3232541.html
Copyright © 2011-2022 走看看