PostgreSQL-6-数据分组

Posted swefii

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PostgreSQL-6-数据分组相关的知识,希望对你有一定的参考价值。

基本语法

SELECT column-list FROM table_name

WHERE [ conditions ]

GROUP BY column1, column2

HAVING [ conditions ]

ORDER BY column1, column2

注意顺序 → WHERE - GROUP BY - HAVING - ORDER BY

 

SELECT classno,COUNT(studentname) FROM student GROUP BY classno;  按照classno字段,分组汇总学生数量

SELECT classno,MIN(age),AVG(age) FROM student GROUP BY classno;  查看每个班级年龄最小值/均值

INSERT INTO company3 VALUES(7,‘pual‘,2000);

INSERT INTO company3 VALUES(8,‘allen‘,3000);

INSERT INTO company3 VALUES(9,‘teddy‘,20000);

SELECT name,SUM(salary) FROM company3 GROUP BY name;  多插入一些重复名称的数据,汇总每个员工的总薪水

 

分组+排序

SELECT classno,COUNT(studentname) FROM student GROUP BY classno ORDER BY classno; 按照classno排序

SELECT name,SUM(salary) FROM company3 GROUP BY name ORDER BY SUM(salary);  按照总薪水排序

 

过滤分组,WHERE

SELECT classno,COUNT(studentname) FROM student

       WHERE classno > 2

       GROUP BY classno; WHERE作用与分组前,这里先筛选classno>2的数据,再分组

       注意,这里如果书写:WHERE COUNT(studentname) > 1 就会报错

 

过滤分组,HAVING

SELECT classno,COUNT(studentname) FROM student

       GROUP BY classno

       HAVING COUNT(studentname) > 1; HAVING主要用于过滤分组,且是在分组后进行过滤

       所以一般对于分组的条件过滤,都用HAVING

以上是关于PostgreSQL-6-数据分组的主要内容,如果未能解决你的问题,请参考以下文章

Postgres 按值更改分区/分组

无法在Linux上登录到新的PostgreSQL数据库

Postgres_FDW 没有推低 WHERE 标准

postgres —— 分组集

Postgres 每小时按数据分组,然后找到 max 和 min createdAt 的时间差并计算它们的总和

对唯一行值进行分组 Postgis、postgres 和 Qgis