美文网首页
MySQL学习日记(二)-服务器的SQL模式

MySQL学习日记(二)-服务器的SQL模式

作者: garvin | 来源:发表于2018-07-30 20:48 被阅读0次

MySQL 服务器有一个名为 sql_mode 的系统变量可以让你调控其 SQL 模式,SQL 模式对 SQL 语句的执行情况有多方面的影响。

SQL 模式: 

STRICT_ALL_TABLES 和 STRICT_TRANS_TABLES 将启用严格模式。(拒绝“坏”数据值,而不是把它们转换为最接近的有效值) 

TRADITIONAL 是一个组合模式。它类似于严格模式,但启用了其他几种引入额外限制条件的模式以进行更加严格的数据检查。在处理“坏”数据值时,更接近于传统的 SQL 服务器。 

ANST_QUOTES 告诉 MySQL 服务器把双引号识别为一个标识符引用字符。 

PIPES_AS_CONCAT 将导致 “||” 字符串被视为一个标准的 SQL 字符串合并操作符,而不是 “OR” 操作符的一个同义词。 

ANSI 是一个组合模式。它将同时启用 ANSI_QUOTES、PIPES_AS_CONCAT 和另外几种模式值,其结果是让 MySQL 服务器的行为比它的默认运行状态更接近于标准的 SQL。

如果想在MySQL启动时设置SQL模式,可以在mysql配置文件中添加sql_mode选项

sql-mode=”TRADITIONAL”

如果在运行过程中修改SQL模式,则可以使用如下命令

mysql>set sql_mode="TRADITIONAL";

mysql的sql_mode合理设置

sql_mode是个很容易被忽视的变量,默认值是空值,在这种设置下是可以允许一些非法操作的,比如允许一些非法数据的插入。在生产环境必须将这个值设置为严格模式,所以开发、测试环境的数据库也必须要设置,这样在开发测试阶段就可以发现问题

sql_mode常用值如下: 

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:

在INSERT或UPDATE过程中,如果数据被零除,则产生错误而非警告。如 果未给出该模式,那么数据被零除时MySQL返回NULL

NO_AUTO_CREATE_USER:

禁止GRANT创建密码为空的用户

NO_ENGINE_SUBSTITUTION:

如果需要的存储引擎被禁用或未编译,那么抛出错误。不设置此值时,用默认的存储引擎替代,并抛出一个异常

PIPES_AS_CONCAT:

将"||"视为字符串的连接操作符而非或运算符,这和Oracle数据库是一样的,也和字符串的拼接函数Concat相类似

ANSI_QUOTES:

启用ANSI_QUOTES后,不能用双引号来引用字符串,因为它被解释为识别符

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'

相关文章

  • MySQL支持的SQL模式介绍

    SQL模式介绍 MySQL服务器可以在不同的SQL操作模式,并能应用这些模式不同的客户,根据不同的价值SQL模式系...

  • MySQL 服务器的 SQL 模式

    MySQL 服务器的 SQL 模式 MySQL 服务器有一个名为 sql_mode 的系统变量可以让你调控其 SQ...

  • MySQL学习日记(二)-服务器的SQL模式

    MySQL 服务器有一个名为sql_mode的系统变量可以让你调控其SQL 模式,SQL 模式对 SQL 语句的执...

  • 各种技术学习之路

    MySQL:《SQL学习指南》、《高性能MySQL》、《高可用MySQL》、《SQL反模式》 参考资料:[MySQ...

  • MySQL SQL Mode

    MySQL服务器可以在不同的SQL模式下运行,并且可以针对不同的客户端以不同的方式应用这些模式,具体取决于sql_...

  • MySQL 之Server SQL Modes

    MySQL SQL modes概述 MySQL服务器可以以不同的SQL Modes运行,并且可以根据sql_mod...

  • MySQL pdo预处理防止sql注入

    PDO执行预处理: 预处理的语法 服务器发送一条sql给mysql服务器,mysql服务器会解析这条sql。 服务...

  • MySql数据库管理 笔记

    文章摘要:1、获得服务器支持的引擎。2、SQL服务器模式3、系统变量4、服务器状态5、MySql通用安全指导6、权...

  • MySQL表名大小写敏感导致的问题

    问题描述 windows服务器上的mysql数据库转储sql文件 Centos服务器上的mysql导入转储sql文...

  • php访问mysql

    步骤 连接mysql服务器 选择mysql数据库 执行sql语句 关闭结果集 关闭mysql服务器 连接服务器 选...

网友评论

      本文标题:MySQL学习日记(二)-服务器的SQL模式

      本文链接:https://www.haomeiwen.com/subject/sgrqvftx.html