MySQL的另类语法

SQL标准 (SQL-92/99)规定:SELECT 列表里的所有字段,要么出现在 GROUP BY 中,要么被聚合函数(MAX/MIN/COUNT 等)包裹。

select id,max(a1) as a1,a2 from a group by id

这句话在任何非MySQL数据库里执行都是语法错。然而MySQL支持。 a2会随机取一行数据的值。当a2和id绑定都是唯一时,这种写法就很简单,但是当a2有多个值时,这个结果是不确定的,也就是今天执行和明天执行,结果可能不一样。

不知道最初MySQL开放者如何脑洞打开,放开了这个限制。而且很多早期开发人员居然也利用了这个特性,导致现在的MySQL也得支持这个特性。当然引入了ONLY_FULL_GROUP_BY参数来进行控制。

系统设计中有很多这样的案例,为了一点微不足道的灵活性,破坏了规则的完整性。个人不建议这么做。如同所有的非MySQL数据库都严格执行,只有MySQL选择了另类。

相关推荐
超哥--1 小时前
B站视频内容智能分析系统(六):Text-to-SQL 结构化查询
数据库·sql·音视频
暗暗别做白日梦1 小时前
Redisson 和redis 实现延迟消息
数据库·redis·缓存
西凉的悲伤1 小时前
redis和数据库实现分布式锁
java·数据库·redis·分布式
zhougl9961 小时前
Database(数据库)和 Schema(模式)
数据库·oracle
专注API从业者1 小时前
告别手动翻页!基于淘宝商品接口 + Open Claw 实现自动化选品与实时监控(附完整 Python 代码)
大数据·运维·数据库·自动化
曹牧1 小时前
Oracle:xml转义
xml·数据库·oracle
湖南天硕国产SSD1 小时前
工业存储可靠性进阶:天硕工业固态硬盘动态温控与寿命优化技术实践
网络·数据库·算法·工业存储·天硕存储·工业固态硬盘
我星期八休息1 小时前
Linux系统编程— Mmap实现⽂件LRU缓存
linux·运维·服务器·数据库·mysql·缓存
小此方1 小时前
Re:Mysql数据库基础篇(三):全面掌握数据库与数据表操作:深度剖析底层文件差异与核心管理机制
数据库·mysql