博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【业务DBA手记八】SQL_MODE详解
阅读量:6096 次
发布时间:2019-06-20

本文共 2336 字,大约阅读时间需要 7 分钟。

hot3.png

1、概述
SQL_MODE可能是比较容易让开发人员和DBA忽略的一个变量,默认为空。SQL_MODE的设置其实是比较冒险的一种设置,因为在这种设置下可以允许一些非法操作,比如可以将NULL插入NOT NULL的字段中,也可以插入一些非法日期,如“2012-12-32”。因此在生产环境中强烈建议开发人员将这个值设为严格模式,这样有些问题可以在数据库的设计和开发阶段就能发现,而如果在生产环境下运行数据库后发现这类问题,那么修改的代价将变得十分巨大。此外,正确地设置SQL_MODE还可以做一些约束(Constraint)检查的工作。
参考:
2、案例说明
 mysql> create table zzy_test1 (c1 char(3));
 mysql> insert into zzy_test1 values('abcd');
 mysql> select * from zzy_test1;
    +------+
    | c1   |
    +------+
    | abc  |
    +------+
    1 row in set (0.00 sec)
我们发现插入的字符被自动截断了,但是如果我们本意希望如果长度超过限制就报错,那么我们可以设置sql_mode为STRICT_TRANS_TABLES,如下:
    mysql> set session sql_mode='STRICT_TRANS_TABLES'
这样我们再执行同样的操作,mysql就会告诉我们插入的值太长,操作被终止,如下:
    mysql> insert into zzy_test1 values('abcd');
    ERROR 1406 (22001): Data too long for column 'c1' at row 1
3、参数说明
ONLY_FULL_GROUP_BY:
对于GROUP BY聚合操作,如果在SELECT中的列,没有在GROUP BY中出现,那么这个SQL是不合法的,因为列不在GROUP BY从句中
NO_AUTO_VALUE_ON_ZERO:
该值影响自增长列的插入。默认设置下,插入0或NULL代表生成下一个自增长值。如果用户 希望插入的值为0,而该列又是自增长的,那么这个选项就有用了。
STRICT_TRANS_TABLES:
在该模式下,如果一个值不能插入到一个事务表中,则中断当前的操作,对非事务表不做限制
NO_ZERO_IN_DATE:
在严格模式下,不允许日期和月份为零
NO_ZERO_DATE:
设置该值,mysql数据库不允许插入零日期,插入零日期会抛出错误而不是警告。
ERROR_FOR_DIVISION_BY_ZERO:
 ERROR_FOR_DIVISION_BY_ZERO:在INSERT或UPDATE过程中,如果数据被零除(或MOD(X,0)),则产生错误(否则为警告)。如果未给出该模式,那么数据被零除时MySQL返回NULL。如果用到INSERT IGNORE或UPDATE IGNORE中,MySQL生成被零除警告,但操作结果为NULL。
NO_AUTO_CREATE_USER:
禁止GRANT创建密码为空的用户
NO_ENGINE_SUBSTITUTION:
如果需要的存储引擎被禁用或未编译,那么抛出错误。不设置此值时,用默认的存储引擎替代,并抛出一个异常
PIPES_AS_CONCAT:
将"||"视为字符串的连接操作符而非或运算符,这和Oracle数据库是一样的,也和字符串的拼接函数Concat相类似
ANSI_QUOTES:
启用ANSI_QUOTES后,不能用双引号来引用字符串,因为它被解释为识别符,只能用单引号
mysql> CREATE TABLE z ( a VARCHAR(10))ENGINE=INNODB;
  Query OK, 0 rows affected (0.00 sec)
  mysql>INSERT INTO z SELECT "aaa";
  Query OK, 1 rows affected (0.00 sec)
  mysql> SET sql_mode='ANSI_QUOTES';
  Query OK, 0 rows affected (0.00 sec)
  mysql> INSERT INTO z SELECT "aaa";
  ERROR 1054 (42S22): Unknown column 'aaa' in 'field list'
ORACLE的sql_mode设置等同:PIPES_AS_CONCAT, ANSI_QUOTES, IGNORE_SPACE, NO_KEY_OPTIONS, NO_TABLE_OPTIONS, NO_FIELD_OPTIONS, NO_AUTO_CREATE_USER.
 
如果使用mysql,为了继续保留大家使用oracle的习惯,可以对mysql的sql_mode设置如下:
 
在my.cnf添加如下配置
[mysqld]
sql_mode='
ONLY_FULL_GROUP_BY, NO_AUTO_VALUE_ON_ZERO, STRICT_TRANS_TABLES, NO_ZERO_IN_DATE, NO_ZERO_DATE,
ERROR_FOR_DIVISION_BY_ZERO, NO_AUTO_CREATE_USER, NO_ENGINE_SUBSTITUTION, PIPES_AS_CONCAT, ANSI_QUOTES'

转载于:https://my.oschina.net/u/1986568/blog/713968

你可能感兴趣的文章
为php添加xcache
查看>>
CSV文件写入,解决汉字乱码
查看>>
linux中查找某个命令是哪个包提供的
查看>>
php验证码类
查看>>
使用curl操作github API V3(1)
查看>>
GNU screen视频教程
查看>>
配置Ipython Nodebook 运行 Python Spark 程序
查看>>
浅谈引导搜索推广
查看>>
USB-FPA在Win7之下的驱动
查看>>
集合框架---Map Set List初步理解
查看>>
海量端口扫描工具masscan
查看>>
Django简介
查看>>
如何在shell下免密码快速登陆MySQL数据库?
查看>>
java1234 shiro 第0 .1课 缓存
查看>>
CSS字体样式
查看>>
传输层TCP与UDP
查看>>
LAMP的搭建
查看>>
history 详解
查看>>
单节点网络改造实例:宝视通网络改造方案
查看>>
简单线性回归和多项式回归
查看>>