再看数据库——(5)Group By与Order By

在使用sql语句时,很多人都会分不清order by与group by,其实简单的说:


order by —— 排序

group by ——分组


1、order by是行的排序,默认为升序。

有两种方式,ASC升序、降序DESC。

其后面必须列出排序的字段名,当然可以是多个字段名。


下面通过例子来看下它的简单用法:

数据库中有一张Apartment表,其表中的字段值如下:



要求:将表中数据按Number列降序排列

/*Apartment为表名*/
select * from Apartment order by Number desc


排列之后的结果如下所示:



扩展:

在排序过程中,如果想要筛选重复项,这时就用到了Distinct关键字。

要求:查出Number的不重复项,并按Number排序。

select distinct Number from Apartment order by Number 

显示结果如下:


2、group by是分组,配合sum(),count()等聚合函数来使用


要求:Number列的分组个数

select count(Number) from Apartment group by Number

查询结果如下:


扩展:

Having子句

帮助我们对分组之后的结果进行筛选

要求:接着上面的要求,求出分组中大于1的

select count(Number) from Apartment group by Number having count(Number)>1


查询结果如下:


小结:

     通过上面的几个例子,就能发现,其实group by 和order by的作用并不相同,而且搭配的用法也不相同。不放过每一个细节,基础才能扎实。sql还有很大的学问去研究。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 12
    评论
在 PostgreSQL 中,GROUP BY 语句和 SELECT 语句可以一起使用来对相同的数据进行分组。GROUP BY 通常放在 WHERE 子句之后和 ORDER BY 子句之前。 下面是 GROUP BY 与 ORDER BY 一起使用的基本语法: SELECT column-list FROM table_name WHERE [ conditions ] GROUP BY column1, column2....columnN ORDER BY column1, column2....columnN 这个语法允许你按照指定的列对结果进行分组,然后按照指定的列对分组结果进行排序。 需要注意的是,如果一个查询中使用了分组函数,那么任何不在分组函数中的列或表达式都必须在 GROUP BY 子句中出现,否则会出错。例如,如果在一个查询中使用了 SUM 函数来计算某列的总和,那么该列必须在 GROUP BY 子句中列出。否则,会出现错误。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [PgSQL——学习笔记八: ORDER BY 子句:排序 & GROUP BY 语句:分组](https://blog.csdn.net/qq_41361442/article/details/124809777)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [group by,having,order by的用法详解](https://download.csdn.net/download/weixin_38543460/13699445)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值