mysql查询mode_MySQL的sql_mode解析与设置

sql_mode类型

sql_mode:它定义了MySQL应该支持的sql语法,对数据的校验等等。

查看MySQL sql_mode类型 show variables like 'sql_mode'

e0a32c325c270fa694645ee9d5ac5a4e.png

1、ONLY_FULL_GROUP_BY:

对于GROUP BY聚合操作,如果在SELECT中的列,没有在GROUP BY中出现,那么将认为这个SQL是不合法的,因为列不在GROUP BY语句中。

因为有only_full_group_by,所以我们要在MySQL中正确的使用group by语句的话,只能是select c1 from t group by c1 (即只能展示group by的字段,其他均都要报1055的错)

示例:select * from user;

8a0a6a2e2ced2e32be3a1426bf6ea917.png

上面username有两个hekai内容。下面就来使用group by操作。

select id,username from user group by username;

844500f722a46788cf4a1e70c2ff8dcf.png

上面的id不在group by字段里面就会报1055错误。

去掉id在查询:select username from user group by username;

c848d19974c7a0eaa14f13af86c98a9c.png

上面的字段hekai合成一行,我们为了看的更清楚,再来一个更清楚的语句。

select username,avg(accessToken) from user group by username;

faabe7805fb3ab28332dbbccb8198650.png

accessToken这行的字段关于hekai就合并并且求了平均数。

如果不想要这样的限制,可以删除sql_mode中的only_full_group_by选项。

2、STRICT_TRANS_TABLES

在该模式下,如果一个值不能插入到一个事务表中,则中断当前的操作,对非事务表不做任何限制。

3、NO_ZERO_IN_DATE

在严格模式,不接受月或日部分为0的日期。如果使用IGNORE选项,我们为类似的日期插入'0000-00-00'。在非严格模式,可以接受该日期,但会生成警告。

4、NO_ZERO_DATE

在严格模式,不要将 '0000-00-00'做为合法日期。你仍然可以用IGNORE选项插入零日期。在非严格模式,可以接受该日期,但会生成警告。

5、ERROR_FOR_DIVISION_BY_ZERO

在严格模式,在INSERT或UPDATE过程中,如果被零除(或MOD(X,0)),则产生错误(否则为警告)。如果未给出该模式,被零除时MySQL返回NULL。如果用到INSERT IGNORE或UPDATE IGNORE中,MySQL生成被零除警告,但操作结果为NULL。

6、NO_AUTO_CREATE_USER

防止GRANT自动创建新用户,除非还指定了密码。

7、NO_ENGINE_SUBSTITUTION

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

sql_mode模式

首先创建一个表:create table testmode(name varchar(2),test varchar(2));

12cfec6e07377b7f8432090daab52a66.png

1、ANSI模式:宽松模式,对插入数据进行校验,如果不符合定义类型或长度,对数据类型调整或截断保存,报warning警告。

先设置模式ANSI:set @@sql_mode=ANSI;

9de5febc7c5c65aa8d1a1e75e69fbf21.png

插入数据:insert into testmode values('11111111','2342342424');

887e4c8a960adbaea94847a0de798517.png

插入成功,报出2条警告。而且只截取了前面2个字符数据。

870a08a1d83790a62d766481d187deb5.png

2、TRADITIONAL模式:严格模式,当向mysql数据库插入数据时,进行数据的严格校验,保证错误数据不能插入,报error错误。用于事物时,会进行事物的回滚。

先设置模式TRADITIONAL:set @@sql_mode=TRADITIONAL;

f0280f113b4a22942639acb882fb664e.png

除了STRICT_TRANS_TABLES之外还有STRICT_ALL_TABLES

STRICT_TRANS_TABLES

对于InnoDB表,sql插入执行失败,会报错,全部回滚。

ae3e713d53d7f6665e9a9d419521ae6c.png

d425d63d9bf81d200561c0bdc2c64db2.png

STRICT_ALL_TABLES

对于InnoDB表,和STRICT_TRANS_TABLES模式相同

15d73b5bcf9850d256a275a62a639283.png

对于MyISAM表,sql插入执行失败会保存错误发生之前修改的行,忽略剩下的行,并报错。

改变engine

f6e106b78d86badbbdaf8deb8a549cff.png

进行操作:

f715c12e1f1839274f5cb11b3af55f55.png

可以看到就算报错,前面执行的行依然插入数据库。

3、STRICT_TRANS_TABLES模式:严格模式,进行数据的严格校验,错误数据不能插入,报error错误。上面已经介绍。

上面设置sql_mode都可以在my.cnf配置文件里面设置。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值