博客
关于我
SQL必知必会 第10课 分组数据
阅读量:179 次
发布时间:2019-02-28

本文共 918 字,大约阅读时间需要 3 分钟。

10.1 数据分组

分组可以将数据分为多个逻辑组,对每个组进行聚集计算。

10.2 创建分组

# GROUP BY 子句指示DBMS按照vend_id 排序并分组数据select vend_id, count(*) as num_prodsfrom productsgroup by vend_id;

在这里插入图片描述

10.3 过滤分组

通过HAVING子句

# 过滤出两个以上订单的分组select cust_id, count(*) as orders from orders group by cust_idhaving count(*) >= 2;

在这里插入图片描述

WHERE 在数据分组前进行过滤,而HAVING 在数据分组之后进行过滤。

# 列出具有两个以上产品且其价格大于等于4的供应商select vend_id, count(*) as onum_prods from productswhere prod_price >= 4group by vend_idhaving count(*) >= 2

在这里插入图片描述

10.4 分组和排序

group by 和 order by 的区别

ORDER BY GROUP BY
对产生的输出排序 对行分组,但输出可能不是分组的顺序
任意列都可以使用 只可能使用选择列或表达式列,而且必须使用每个选择列表达式
不一定需要 如果与聚集函数一起使用列(或表达式),则必须使用

一般在使用GROUP BY子句时,应该也给出ORDER BY子句。这是保证数据正确排序的唯一方法。

# 按订购物品的数目排序输出select order_num, count(*) as items from orderItemsgroup by order_numhaving count(*) >= 3order by items, order_num;

在这里插入图片描述

10.5 select 子句顺序

子句 说明 是否必须使用
SELECT 要返回的列或表达式
FROM 从中检索数据的表 仅在从表选择数据时使用
WHERE 行级过滤
GROUP BY 分组说明 仅在按组计算聚集时使用
HAVING 组级过滤
ORDER BY 输出排序顺序

转载地址:http://jgpn.baihongyu.com/

你可能感兴趣的文章
Neat Stuff to Do in List Controls Using Custom Draw
查看>>
Necurs僵尸网络攻击美国金融机构 利用Trickbot银行木马窃取账户信息和欺诈
查看>>
Needle in a haystack: efficient storage of billions of photos 【转】
查看>>
NeHe OpenGL教程 07 纹理过滤、应用光照
查看>>
NeHe OpenGL教程 第四十四课:3D光晕
查看>>
Neighbor2Neighbor 开源项目教程
查看>>
neo4j图形数据库Java应用
查看>>
Neo4j图数据库_web页面关闭登录实现免登陆访问_常用的cypher语句_删除_查询_创建关系图谱---Neo4j图数据库工作笔记0013
查看>>
Neo4j图数据库的介绍_图数据库结构_节点_关系_属性_数据---Neo4j图数据库工作笔记0001
查看>>
Neo4j图数据库的数据模型_包括节点_属性_数据_关系---Neo4j图数据库工作笔记0002
查看>>
Neo4j安装部署及使用
查看>>
Neo4j电影关系图Cypher
查看>>
Neo4j的安装与使用
查看>>
Neo4j(1):图数据库Neo4j介绍
查看>>
Neo4j(2):环境搭建
查看>>
Neo4j(3):Neo4j Desktop安装
查看>>
Neo4j(4):Neo4j - CQL使用
查看>>
Neo图数据库与python交互
查看>>
NEO改进协议提案1(NEP-1)
查看>>
Neo私链
查看>>