MySQL GROUP BY 语句
GROUP BY 语句根据一个或多个列对结果集进行分组。
在分组的列上我们可以使用 COUNT, SUM, AVG,等函数。
data:image/s3,"s3://crabby-images/189be/189be7c82284f8ba3c9ec833b252eaa094e5953e" alt=""
实例演示
data:image/s3,"s3://crabby-images/6c038/6c03810330df4e748ee3dc731a3b1333b3e12f15" alt=""
将数据表按名字进行分组,并统计每个人有多少条记录:
data:image/s3,"s3://crabby-images/62489/6248972dfd1d40f658343c1bbccf7c6abdd0f20e" alt=""
使用 WITH ROLLUP
WITH ROLLUP 可以实现在分组统计数据基础上再进行相同的统计(SUM,AVG,COUNT…)。
data:image/s3,"s3://crabby-images/96bb0/96bb07df9f8010fefd40d6f5fe85068e4987056c" alt=""
其中记录 NULL 表示所有人的登录次数。
我们可以使用 coalesce 来设置一个可以取代 NUll 的名称,coalesce 语法:select coalesce(a,b,c);
参数说明:如果a==null,则选择b;如果b==null,则选择c;如果a!=null,则选择a;如果a b c 都为null ,则返回为null(没意义)。
以下实例中如果名字为空我们使用总数代替:
data:image/s3,"s3://crabby-images/8eeb6/8eeb6ba04e11b0b2780133ee61f68aac0f36e52f" alt=""
data:image/s3,"s3://crabby-images/b84bc/b84bcb952ce471a1eb603379325f75483151dec4" alt=""
网友评论