加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

MySQL运用GROUP BY分组查询

发布时间:2021-06-02 13:41:56 所属栏目:编程 来源:互联网
导读:GROUP BY单独行使 单独行使 GROUP BY 要害字时,查询功效会只表现每个分组的第一笔记录。 例 1 下面按照 tb_students_info 表中的 sex 字段举办分组查询,SQL 语
GROUP BY单独行使 单独行使 GROUP BY 要害字时,查询功效会只表现每个分组的第一笔记录。
例 1 下面按照 tb_students_info 表中的 sex 字段举办分组查询,SQL 语句和运行功效如下: mysql> SELECT `name`,`sex` FROM tb_students_info -> GROUP BY sex; +-------+------+ | name | sex | +-------+------+ | Henry | 女 | | Dany | 男 | +-------+------+ 2 rows in set (0.01 sec) 功效中只表现了两笔记录,这两笔记录的 sex 字段的值别离为“女”和“男”。
GROUP BY 与 GROUP_CONCAT()  GROUP BY 要害字可以和 GROUP_CONCAT() 函数一路行使。GROUP_CONCAT() 函数会把每个分组的字段值都表现出来。 例 2 下面按照 tb_students_info 表中的 sex 字段举办分组查询,行使 GROUP_CONCAT() 函数将每个分组的 name 字段的值都表现出来。SQL 语句和运行功效如下: mysql> SELECT `sex`, GROUP_CONCAT(name) FROM tb_students_info -> GROUP BY sex; +------+----------------------------+ | sex | GROUP_CONCAT(name) | +------+----------------------------+ | 女 | Henry,Jim,John,Thomas,Tom | | 男 | Dany,Green,Jane,Lily,Susan | +------+----------------------------+ 2 rows in set (0.00 sec) 由功效可以看到,查询功效分为两组,sex 字段值为“女”的是一组,值为“男”的是一组,且每组的门生姓名都表现出来了。 例 3 下面按照 tb_students_info 表中的 age 和 sex 字段举办分组查询。SQL 语句和运行功效如下:
mysql> SELECT age,sex,GROUP_CONCAT(name) FROM tb_students_info -> GROUP BY age,sex; +------+------+--------------------+ | age | sex | GROUP_CONCAT(name) | +------+------+--------------------+ | 21 | 女 | John | | 22 | 女 | Thomas | | 22 | 男 | Jane,Lily | | 23 | 女 | Henry,Tom | | 23 | 男 | Green,Susan | | 24 | 女 | Jim | | 25 | 男 | Dany | +------+------+--------------------+ 7 rows in set (0.00 sec) 上面实例在分组进程中,先凭证 age 字段举办分组,当 age 字段值相称时,再把 age 字段值相称的记录凭证 sex 字段举办分组。

多个字段分组查询时,会先凭证第一个字段举办分组。假如第一个字段中有沟通的值,MySQL 才会凭证第二个字段举办分组。假如第一个字段中的数据都是独一的,那么 MySQL 将不再对第二个字段举办分组。

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读