当前位置: 首页 >数据库 > 用MySQL碰到的一些“坑”

用MySQL碰到的一些“坑”

  本篇文章持续更新。

  这里说坑,也不算坑,只是对我一个经常用SQL Server的来说有点不习惯而已。

  一、GroupBy 的不同

create table Customer (CustomerNumber varchar(50),PayMentDate datetime,Amount int)insert into Customer(CustomerNumber,PayMentDate,Amount)select '103','2018-01-02','123.01' union allselect '103','2018-01-08','123.01' union allselect '115','2018-01-04','123.01' union allselect '112','2018-01-05','123.01' union allselect '115','2018-01-08','123.01' union allselect '112','2018-01-10','123.01' union allselect '114','2018-01-06','123.01' ;

  根据上面的数据,我们执行如下SQL语句:

      select CustomerNumber,PayMentDate from  Customer group by CustomerNumber

      第一反应,看到这条SQL,我说这不是会报错吗(按照以前在SQLServer的逻辑)。

      实际上是不会报错的。

      虽然大家不推荐这么干,但是上面的写法确实是不会报错的,因为MySQL会给我们(非分组字段)加默认的聚合函数。

      真正的原因:MySQL里面是通过sql_Model来提供SQL语句的合法检查,在mysql的sql_model=default的情况下

      是允许刚刚上面这种做法的,也就是说一条select语句,除了聚合函数和group by column以外的表达式(这个表达式的值无法确定)

    实际上是MySQL的分组内第一行对应列的值)

  而很多对语义限制比较严的多家数据库,如SQLServer,Oracle,PostgreSql都不支持select trage list 中出现语义不明确的列。

    所以MySQL在后续的版本中出现了一个修正的语义,也就是我们说的ONLY_FULL_GROUP_BY的语义。

set sql_mode=ONLY_FULL_GROUP_BY;select CustomerNumber,PayMentDate from  Customer group by CustomerNumber;

    上面这样写就会报错:说PayMentDate不在Group By 的列中。

  不管我们是否设置:

       set sql_mode=ONLY_FULL_GROUP_BY

  我们都应该按照严格的语义来写,不然给后面维护带来不方便。

  二、删除数据

  一开始的删除数据,直接写了下面个子查询,然后就交给DBA,去正式的库执行,之后反馈说,报错了,不能执行。

delete from Customerwhere CustomerNumber in (  select CustomerNumber from payments);

  上面这个做法为什么错呢,因为MySQL不允许在安全模式下,删除数据不通过主键来删除。

  正确的做法:

  把安全更新设置为零,用完再设置回1。

SET SQL_SAFE_UPDATES = 0;delete from Customerwhere CustomerNumber in (  select CustomerNumber from payments);SET SQL_SAFE_UPDATES=1;

  从这里也可以看出,我们进行删除数据这些操作,还是尽量的用主键好。主键能够保证不会多删,并且效率也高。

作者:GDOUJKZZ
来源链接:https://www.cnblogs.com/gdouzz/p/10841607.html

版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。

2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。





本文链接:https://www.javaclub.cn/database/118139.html

标签:group by
分享给朋友:

“用MySQL碰到的一些“坑”” 的相关文章

一文带你了解MySQL基础 2022年05月15日 09:35:43
MySQL面试有这一篇就够了 2022年05月16日 21:53:45
MySQL 查询指定时间范围内的数据 2022年06月06日 16:59:25
mysql查询结果中文显示成了问号 2022年06月07日 02:00:43
mysql查询重复的 2022年06月12日 13:49:33
mysql查询前几条记录 2022年06月13日 21:46:10
MySQL查询请求执行过程分析 2022年06月15日 10:06:22
mysql 近几天内 2022年06月15日 15:07:52