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


order by —— 排序

group by ——分组


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

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

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


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

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

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


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

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


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


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


扩展:

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

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

select distinct Number from Apartment order by Number 

显示结果如下:

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

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


要求:Number列的分组个数

select count(Number) from Apartment group by Number

查询结果如下:

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

扩展:

Having子句

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

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

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


查询结果如下:

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

小结:

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

相关文章:

  • 2022-12-23
  • 2021-08-11
  • 2022-02-14
  • 2021-08-12
  • 2021-07-13
  • 2022-03-06
猜你喜欢
  • 2021-08-25
  • 2021-07-02
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案