在 SQL 中,区分 聚合列 和 非聚合列(nonaggregated column)

文章目录

      • 1. 什么是聚合列?
      • 2. 什么是非聚合列?
      • 3. 在 `GROUP BY` 查询中的非聚合列
        • 问题示例
        • 解决方案
      • 4. 为什么 `only_full_group_by` 要求非聚合列出现在 `GROUP BY` 中?
      • 5. 如何判断一个列是聚合列还是非聚合列?
      • 6. 总结

在 SQL 中, 非聚合列是指那些没有使用聚合函数(如 COUNTSUMAVGMAXMIN 等)的列。理解这个概念的关键在于区分 聚合列非聚合列


1. 什么是聚合列?

聚合列是指使用了聚合函数的列。聚合函数会对一组值进行计算,并返回一个单一的值。例如:

  • COUNT(*):计算行数。
  • SUM(column):计算某列的总和。
  • AVG(column):计算某列的平均值。
  • MAX(column):返回某列的最大值。
  • MIN(column):返回某列的最小值。

示例

SELECT COUNT(*) AS total_users FROM users;
  • 这里的 COUNT(*) 是一个聚合列,因为它使用了聚合函数 COUNT

2. 什么是非聚合列?

非聚合列是指没有使用聚合函数的列。这些列直接来自表中的数据,而不是通过计算得到的。

示例

SELECT name, age FROM users;
  • 这里的 nameage 都是非聚合列,因为它们直接来自表中的数据,没有使用任何聚合函数。

3. 在 GROUP BY 查询中的非聚合列

当使用 GROUP BY 时,查询会将数据按指定的列分组。对于非聚合列,MySQL 需要明确知道如何选择值,因为每个分组可能包含多行数据。

问题示例

假设有一个表 users,数据如下:

idnameage
1Alice20
2Bob20
3Charlie25

执行以下查询:

SELECT name, age, COUNT(*) FROM users GROUP BY age;
  • 这里的 age 是分组列,COUNT(*) 是聚合列。
  • name 是非聚合列,它没有出现在 GROUP BY 子句中,也没有使用聚合函数。
  • MySQL 不知道在分组后应该选择哪个 name 值(因为 age=20 对应两个 nameAliceBob)。
解决方案
  1. 将非聚合列添加到 GROUP BY 子句中

    SELECT name, age, COUNT(*) FROM users GROUP BY name, age;
    
    • 这样,MySQL 会按 nameage 分组,确保每个分组只有一行数据。
  2. 使用聚合函数处理非聚合列

    SELECT MAX(name), age, COUNT(*) FROM users GROUP BY age;
    
    • 这里使用 MAX(name),表示选择每个分组中 name 的最大值。

4. 为什么 only_full_group_by 要求非聚合列出现在 GROUP BY 中?

only_full_group_by 模式的目的是确保查询结果的明确性。如果没有这个限制,MySQL 可能会随机选择一个值作为非聚合列的结果,导致查询结果不可预测。

示例

SELECT name, age, COUNT(*) FROM users GROUP BY age;
  • 如果 age=20 对应两个 nameAliceBob),MySQL 可能随机返回 AliceBob,这会导致结果不一致。

通过启用 only_full_group_by,MySQL 会强制要求所有非聚合列都出现在 GROUP BY 子句中,从而避免这种不确定性。


5. 如何判断一个列是聚合列还是非聚合列?

  • 聚合列:使用了聚合函数(如 COUNTSUMAVGMAXMIN 等)。
  • 非聚合列:直接来自表中的数据,没有使用聚合函数。

示例

SELECT name, age, COUNT(*) AS total_users FROM users GROUP BY name, age;
  • nameage 是非聚合列。
  • COUNT(*) 是聚合列。

6. 总结

  • 非聚合列是指没有使用聚合函数的列,直接来自表中的数据。
  • GROUP BY 查询中,所有非聚合列必须出现在 GROUP BY 子句中,或者使用聚合函数处理。
  • only_full_group_by 模式的作用是确保查询结果的明确性,避免不明确的值。

通过理解聚合列和非聚合列的区别,可以更好地编写符合 only_full_group_by 要求的 SQL 查询。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/64964.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

petalinux2017.4对linux4.9.0打实时补丁

准备工作: 1.windows:安装vivado 2017.4,xilinx sdk 2017.4 2.ubuntu16.04:安装petalinux 2017 3.黑金ax7020,sd卡 一、准备linux内核的操作系统 1.1 Petalinux配置 Petalinux使用教程-CSDN博客非常详细&#xf…

Golang的缓存一致性策略

Golang的缓存一致性策略 一致性哈希算法 在Golang中,缓存一致性策略通常使用一致性哈希算法来实现。一致性哈希算法能够有效地解决缓存节点的动态扩容、缩容时数据重新分布的问题,同时能够保证数据访问的均衡性。 一致性哈希算法的核心思想是将节点的哈希…

蓝桥杯JAVA--003

需求 2.代码 public class RegularExpressionMatching {public boolean isMatch(String s, String p) {if (p.isEmpty()) {return s.isEmpty();}boolean firstMatch !s.isEmpty() && (s.charAt(0) p.charAt(0) || p.charAt(0) .);if (p.length() > 2 && p…

被催更了,2025元旦源码继续免费送

“时间从来不会停下,它只会匆匆流逝。抓住每一刻,我们才不会辜负自己。” 联系作者免费领💖源💖码。 三联支持:点赞👍收藏⭐️留言📝欢迎留言讨论 更多内容敬请期待。如有需要源码可以联系作者免…

WebRTC的线程事件处理

1. 不同平台下处理事件的API: Linux系统下,处理事件的API是epoll或者select;Windows系统下,处理事件的API是WSAEventSelect,完全端口;Mac系统下,kqueue 2. WebRTC下的事件处理类: …

关于Zotero

1、文献数据库: Zotero的安装 Zotero安装使用_zotero只能安装在c盘吗-CSDN博客 2、如何使用zotero插件 我刚下载的时候就结合使用的是下面的这两个博主的分享,感觉暂时是足够的。 Zotero入🚪基础 - 小红书 Green Frog申请easyscholar密钥…

企业三要素如何用PHP实现调用

一、什么是企业三要素? 企业三要素即传入的企业名称、法人名称、社会统一信用代码或注册号,校验此三项是否一致。 二、具体怎么样通过PHP实现接口调用? 下面我们以阿里云为例,通过PHP示例代码进行调用,参考如下&…

OJ随机链表的复制题目分析

题目内容: 138. 随机链表的复制 - 力扣(LeetCode) 分析: 这道题目,第一眼感觉非常乱,这是正常的,但是我们经过仔细分析示例明白后,其实也并不是那么难。现在让我们一起来分析分析…

uc/os-II 原理及应用(一) 嵌入式实时系统基本概念

基于嵌入式实时操作系统μCOS-II原理及应用(第2版)-任哲 自行网上寻找资源。 计算机系统的中分为计算机硬件系统与计算机软件系统,计算机软件系统由上到下分为,应用软件,系统软件,操作系统;操作系统一般在计算机软件的最低层&…

【Multisim用74ls92和90做六十进制】2022-6-12

缘由Multisim如何用74ls92和90做六十进制-其他-CSDN问答 74LS92、74LS90参考

【UE5 C++课程系列笔记】21——弱指针的简单使用

目录 概念 声明和初始化 转换为共享指针 打破循环引用 弱指针使用警告 概念 在UE C 中,弱指针(TWeakPtr )也是一种智能指针类型,主要用于解决循环引用问题以及在不需要强引用保证对象始终有效的场景下,提供一种可…

数据库知识汇总2

一. 范式 定义:范式是符合某一种级别的关系模式的集合。 关系数据库中的关系必须满足一定的要求。满足不同程度要求的为不同范式; 一个低一级范式的关系模式,通过模式分解(schema decomposition)可以转换为若干个高一…

Flash Attention V3使用

Flash Attention V3 概述 Flash Attention 是一种针对 Transformer 模型中注意力机制的优化实现,旨在提高计算效率和内存利用率。随着大模型的普及,Flash Attention V3 在 H100 GPU 上实现了显著的性能提升,相比于前一版本,V3 通…

【51单片机零基础-chapter6:LCD1602调试工具】

实验0-用显示屏LCD验证自己的猜想 如同c的cout,前端的console.log() #include <REGX52.H> #include <INTRINS.H> #include "LCD1602.h" int var0; void main() {LCD_Init();LCD_ShowNum(1,1,var211,5);while(1){;} }实验1-编写LCD1602液晶显示屏驱动函…

Ubuntu22.04双系统安装记录

1.Ubuntu24.04在手动分区时&#xff0c;没有efi选项&#xff0c;需要点击分区界面左下角&#xff0c;选择efi的位置&#xff0c;然后会自动创建/boot/efi分区&#xff0c;改到2GB大小即可。 2.更新Nvidia驱动后&#xff0c;重启电脑wifi消失&#xff0c;参考二选一&#xff1a…

Python Notes 1 - introduction with the OpenAI API Development

Official document&#xff1a;https://platform.openai.com/docs/api-reference/chat/create 1. Use APIfox to call APIs 2.Use PyCharm to call APIs 2.1-1 WIN OS.Configure the Enviorment variable #HK代理环境&#xff0c;不需要科学上网(价格便宜、有安全风险&#…

《Vue3实战教程》40:Vue3安全

如果您有疑问&#xff0c;请观看视频教程《Vue3实战教程》 安全​ 报告漏洞​ 当一个漏洞被上报时&#xff0c;它会立刻成为我们最关心的问题&#xff0c;会有全职的贡献者暂时搁置其他所有任务来解决这个问题。如需报告漏洞&#xff0c;请发送电子邮件至 securityvuejs.org。…

【Rust自学】10.2. 泛型

喜欢的话别忘了点赞、收藏加关注哦&#xff0c;对接下来的教程有兴趣的可以关注专栏。谢谢喵&#xff01;(&#xff65;ω&#xff65;) 题外话&#xff1a;泛型的概念非常非常非常重要&#xff01;&#xff01;&#xff01;整个第10章全都是Rust的重难点&#xff01;&#xf…

Spark-Streaming有状态计算

一、上下文 《Spark-Streaming初识》中的NetworkWordCount示例只能统计每个微批下的单词的数量&#xff0c;那么如何才能统计从开始加载数据到当下的所有数量呢&#xff1f;下面我们就来通过官方例子学习下Spark-Streaming有状态计算。 二、官方例子 所属包&#xff1a;org.…

Python 3 输入与输出指南

文章目录 1. 输入与 input()示例&#xff1a;提示&#xff1a; 2. 输出与 print()基本用法&#xff1a;格式化输出&#xff1a;使用 f-string&#xff08;推荐&#xff09;&#xff1a;使用 str.format()&#xff1a;使用占位符&#xff1a; print() 的关键参数&#xff1a; 3.…