2022-09-08
分组函数
1、按照某个字段分组并查询(group by)
以"students"表(id,name,age,gender,is_del,height)为例:- select gender from students group by gender;
复制代码 说明:格式:select 字段名 from 表名 group by 要分组的字段名;
2、一张表中,按照某个字段分组后,查询某个字段分组后值的集合(group_concat)
以"students"表为例:- select gender,group_concat(name) from students group by gender;
复制代码 说明:select 某个字段名1,grouP_concat(要以集合分布的字段名) from 表名 group by 某个字段名1;
结果图如下:

3、对分组数据进行过滤(having)
以"students"表为例:- select gender,count(*) from students group by gender having count(*) > 3;
复制代码 查询分组中数量大于3的gender 中的属性以及统计它的人数。
4、对分组数据中的聚合函数进行汇总(with rollup)
以"students"表为例:- select gender,count(*) from students group by gender with rollup;
复制代码 查询某个字段中,分组数据的个数统计。除此之外,结果表中还有NULL属性的统计,它的值是分组数据中总的数据的个数之和。
结果表如下:

--------------------------------------------------------
内连接(inner join ):
指的是两个表中符合条件的共有数据。即两个表的交集部分。
5、使用内连接查询两个表的联系情况:
前提:
例如:现创建了两个表。
表1 students(id,name,age,gender,id_del,height,c_id,); 表2 classes(id,name)。- select s.name,c.name from students s inner join classes c on s.c_id = c.id;
复制代码 说明:students s 和 classes c 表示的是给某个表起一个别名,其中起别名的关键字as可以省略。
格式:select 表名.字段名(结果图中要列出的内容)from 表名1 表1别名 inner join 表名2 表2别名 on 连接约束条件(表1.字段名 = 表2.字段名);
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |