【MySQL 的 ONLY_FULL_GROUP_BY 模式】
弁言:作为一个菜鸟,当写sql中涉及到group by这样简单的语句时,也会出现题目,我在牛客网上做sql题时,总报这个错:
https://i-blog.csdnimg.cn/direct/d75a6de6bf79473fabb681ed45b0157a.png ONLY_FULL_GROUP_BY 到底是什么东西呢?
本日写篇文章解释一下。
一、GROUP BY使用时的关键要点
1. 理解 GROUP BY 的作用
GROUP BY 用于将数据集分割成多个组,每个组由一组具有相同属性的行构成。这使得聚合函数可以应用于每一组,而不是整个数据集。例如,使用 GROUP BY 可以按产品种别统计贩卖总额。
2. 服从 ONLY_FULL_GROUP_BY 规则
在 MySQL 中,如果启用了 ONLY_FULL_GROUP_BY 模式,那么 SELECT 子句中除聚合函数之外的全部列都必须在 GROUP BY 子句中出现。这是为了避免不确定性和潜伏的数据歧义。
3. 使用 HAVING 举行条件过滤
HAVING 子句用于对分组后的结果举行过滤,雷同于 WHERE 子句,但 HAVING 实用于聚合结果。例如,你可以使用 HAVING COUNT(*) > 1 来找出至少出现两次的组。
4. 正确排序结果
固然 GROUP BY 自身不会自动排序结果,但你通常会渴望在结果会合应用 ORDER BY 来排序分组。例如,你可以按贩卖额降序排序产品种别。
5. 注意空值和 NULL 值
在 GROUP BY 中,NULL 值会被视为相同的值,这意味着全部包含 NULL 的行会被归入同一组。如果需要区分 NULL 和非 NULL 值,可以使用 COALESCE() 或者条件表达式。
二、 ONLY_FULL_GROUP_BY 规则
1. 什么是 ONLY_FULL_GROUP_BY?
ONLY_FULL_GROUP_BY 是 MySQL 中的一个 SQL 模式,它要求在任何包含聚合函数的查询中,全部在 SELECT 子句中出现的非聚合列也必须在 GROUP BY 子句中出现。换句话说,如果一个查询使用了聚合函数,那么除了聚合函数包裹的列以外,全部在 SELECT 子句中出现的列都必须被 GROUP BY 子句引用。
这个规则确保了查询结果的确定性和一致性,避免了由于 SQL 语句的模糊性而导致的潜伏错误。
2. 为什么需要 ONLY_FULL_GROUP_BY?
在 ONLY_FULL_GROUP_BY 被引入之前,MySQL 允许在没有 GROUP BY 或者 GROUP BY 不充实的环境下举行查询。这意味着,纵然查询中包含了没有被聚合的列,MySQL 也会返回任意一个结果,这可能会导致误导性的结果或数据丢失。
例如,假设我们有以下查询:
SELECT prod_name, COUNT(order_num)
FROM products p
JOIN orders o ON p.prod_id = o.prod_id;
这里,prod_name 列没有被聚合函数包裹,也没有在 GROUP BY 子句中出现。在 ONLY_FULL_GROUP_BY 模式下,这个查询会失败,因为 MySQL 不知道如何从多个可能的 prod_name 值中选择一个来展示。
3.如何启用或禁用 ONLY_FULL_GROUP_BY?
在 MySQL 中,默认环境下 ONLY_FULL_GROUP_BY 是启用的。你可以通过查抄 @@sql_mode 体系变量来确认这一点:
SELECT @@sql_mode;
如果 ONLY_FULL_GROUP_BY 已经被启用,并且你想要暂时禁用它(只管这不是一个保举的恒久解决方案),你可以通过以下命令在会话级禁用它:
SET SESSION sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY',''));
或者,你也可以在 MySQL 配置文件(my.cnf 或 my.ini)中修改 sql_mode 设置来全局禁用它。
总结
固然禁用 ONLY_FULL_GROUP_BY 可能会方便一些查询的编写,但从久远来看,遵循这个规则对于保持数据查询的准确性和一致性至关紧张。在编写 SQL 查询时,始终应确保遵循 ONLY_FULL_GROUP_BY 的指导原则,以避免潜伏的数据解释错误。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页:
[1]