SQL语句having、group by、limit、distinc

目录

一、SQL HAVING 语句

1. SQL HAVING 语法

2. SQL HAVING 实例

二、SQL的MAX()函数和MIN()函数

MIN() 函数

1. SQL MIN() 语法

2. SQL MIN() 实例

面试真题:SQL查询出每门课都大于80 分的学生姓名

三、SQL的limit

四、SQL SELECT DISTINCT 语句 

语法:

"Orders"表:

使用 DISTINCT 关键词

五、SQL GROUP BY 语句

SQL GROUP BY 语法

SQL GROUP BY 实例

现在,我们希望查找每个客户的总金额(总订单)。

我们看一看省略SUM如果选了不止一个的OrderPrice会怎么样:

省略SUM如果选了只有一个的name会怎么样:不会报错

让我们看一下如果省略 GROUP BY 会出现什么情况:



一、SQL HAVING 语句

在 SQL 中增加 HAVING 子句原因是,WHERE 关键字无法与合计函数一起使用。

1. SQL HAVING 语法

SELECT column_name, aggregate_function(column_name)
FROM table_name
WHERE column_name operator value
GROUP BY column_name
HAVING aggregate_function(column_name) operator value
ORDER BY field ASC/DESC (默认升序ASC 1,2...)
limit count

 

需要注意的是:

当同时含有where子句、group by 子句 、having子句及聚集函数时,执行顺序如下:

执行where子句查找符合条件的数据;

使用group by 子句对数据进行分组;对group by 子句形成的组运行聚集函数计算每一组的值;

最后用having 子句去掉不符合条件的组。

having子句限制的是组,而不是行。where子句中不能使用聚集函数,而having子句中可以。 

2. SQL HAVING 实例

我们拥有下面这个 "Orders" 表:

O_IdOrderDateOrderPriceCustomer
12008/12/291000Bush
22008/11/231600Carter
32008/10/05700Bush
42008/09/28300Bush
52008/08/062000Adams
62008/07/21100Carter

现在,我们希望查找订单总金额少于 2000 的客户。

我们使用如下 SQL 语句:

select Customer,SUM(OrderPrice) 
from Orders 
group by Customer 
having SUM(OrderPrice) < 2000

结果集类似:

CustomerSUM(OrderPrice)
Carter1700

现在我们希望查找客户 "Bush" 或 "Adams" 拥有超过 1500 的订单总金额。

我们在 SQL 语句中增加了一个普通的 WHERE 子句:

SELECT Customer,SUM(OrderPrice) FROM Orders
WHERE Customer='Bush' OR Customer='Adams'
GROUP BY Customer
HAVING SUM(OrderPrice)>1500

结果集:

CustomerSUM(OrderPrice)
Bush2000
Adams2000

二、SQL的MAX()函数和MIN()函数

MIN() 函数

MIN 函数返回一列中的最小值。NULL 值不包括在计算中。

1. SQL MIN() 语法

SELECT MIN(column_name) FROM table_name

注释:MIN 和 MAX 也可用于文本列,以获得按字母顺序排列的最高或最低值。

2. SQL MIN() 实例

我们拥有下面这个 "Orders" 表:

O_IdOrderDateOrderPriceCustomer
12008/12/291000Bush
22008/11/231600Carter
32008/10/05700Bush
42008/09/28300Bush
52008/08/062000Adams
62008/07/21100Carter

现在,我们希望查找 "OrderPrice" 列的最小值。

我们使用如下 SQL 语句:

SELECT MIN(OrderPrice) AS SmallestOrderPrice FROM Orders

结果集类似这样:

SmallestOrderPrice
100

面试真题:SQL查询出每门课都大于80 分的学生姓名

Course表如下:

查询出每门课都大于80 分的学生姓名有两种方法。

1.select  distinct name from Course where name not in (select distinct name from Course where score<=80) 

2.select  name from Course group by name having min(score)>80

select name 
from Course 
group by name 
having min(score)>80

三、SQL的limit

Product表:

limit语法:

下面的SQL语句,limit只有一个参数值,将表中的前三条数据查询出来 

select <列名>,<列名>,...from <表名> limit <参数值>;
 
select * from product limit 3;
 
+------------+--------------+--------------+------------+----------------+-------------+
| product_id | product_name | product_type | sale_price | purchase_price | regist_date |
+------------+--------------+--------------+------------+----------------+-------------+
| 0001       | T恤衫        | 衣服         |       1000 |            500 | 2009-09-20  |
| 0002       | 打孔器       | 办公用品     |        500 |            320 | 2009-09-11  |
| 0003       | 运动T恤      | 衣服         |       4000 |           2800 | NULL        |
+------------+--------------+--------------+------------+----------------+-------------+

下面的SQL语句,limit有两个参数,第一个参数表示从第几行数据开始查,第二个参数表示查几条数据,“limit 3,2”表示从第四行数据开始,取两条数据。

select <列名>,<列名>,...from <表名> limit <参数值>,<参数值>;
 
select * from product limit 3,2;
 
+------------+--------------+--------------+------------+----------------+-------------+
| product_id | product_name | product_type | sale_price | purchase_price | regist_date |
+------------+--------------+--------------+------------+----------------+-------------+
| 0004       | 菜刀         | 厨房用具     |       3000 |           2800 | 2009-09-20  |
| 0005       | 高压锅       | 厨房用具     |       6800 |           5000 | 2009-01-15  |
+------------+--------------+--------------+------------+----------------+-------------+

四、SQL SELECT DISTINCT 语句 

在表中,可能会包含重复值。这并不成问题,不过,有时您也许希望仅仅列出不同(distinct)的值。

关键词 DISTINCT 用于返回唯一不同的值。

语法:

SELECT DISTINCT 列名称 FROM 表名称

"Orders"表:

CompanyOrderNumber
IBM3532
W3School2356
Apple4698
W3School6953

使用 DISTINCT 关键词

如果要从 "Company" 列中选取所有的值,我们需要使用 SELECT 语句:

SELECT Company FROM Orders

结果:请注意,在结果集中,W3School 被列出了两次。

Company
IBM
W3School
Apple
W3School

 如需从 Company" 列中仅选取唯一不同的值,我们需要使用 SELECT DISTINCT 语句:

SELECT DISTINCT Company FROM Orders 

结果:现在,在结果集中,"W3School" 仅被列出了一次。

Company
IBM
W3School
Apple

五、SQL GROUP BY 语句

GROUP BY 语句用于结合合计函数,根据一个或多个列对结果集进行分组。

SQL GROUP BY 语法

SELECT column_name, aggregate_function(column_name)
FROM table_name
WHERE column_name operator value
GROUP BY column_name

SQL GROUP BY 实例

"Orders" 表:

O_IdOrderDateOrderPriceCustomer
12008/12/291000Bush
22008/11/231600Carter
32008/10/05700Bush
42008/09/28300Bush
52008/08/062000Adams
62008/07/21100Carter

现在,我们希望查找每个客户的总金额(总订单)。

我们想要使用 GROUP BY 语句对客户进行组合。

我们使用下列 SQL 语句:

SELECT Customer,SUM(OrderPrice) 
FROM Orders
GROUP BY Customer

 结果集类似这样:

CustomerSUM(OrderPrice)
Bush2000
Carter1700
Adams2000

很棒吧,对不对?

我们看一看省略SUM如果选了不止一个的OrderPrice会怎么样:

SELECT Customer,OrderPrice FROM orders GROUP BY Customer

报错:

省略SUM如果选了只有一个的name会怎么样:不会报错

题目:SQL查询出每门课都大于80分的学生姓名

Course表如下:

在这里插入图片描述

SQL语句:

select name 
from Course 
group by name 
having min(score)>80

 在这里插入图片描述

 

让我们看一下如果省略 GROUP BY 会出现什么情况:

SELECT Customer,SUM(OrderPrice) FROM Orders

结果集类似这样:下面的结果集不是我们需要的。因为有group by的时候会先执行group by再执行select

CustomerSUM(OrderPrice)
Bush5700
Carter5700
Bush5700
Bush5700
Adams5700
Carter5700
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MySQL中可以使用DISTINCT关键字去除重复数据,语法如下: SELECT DISTINCT 列名 FROM 表名; 其中,列名是需要去重的列名,表名是需要查询的表名。使用DISTINCT关键字可以保证查询结果中不会出现重复的数据。 ### 回答2: MySQL是一个基于关系型数据库管理系统(RDBMS)的软件,它支持多种数据对象,包括表单、视图、存储过程、函数和触发器等等。在MySQL中去除重复数据的方法就是使用关键字DISTINCT。DISTINCT可以去除表中重复数据,使得结果集中每个字段的值都不同。 DISTINCT的语法格式为:SELECT DISTINCT column1, column2, column3, ... FROM table_name; 其中,column1, column2, column3是需要选择的列,可以输入多个,中间用逗号隔开;table_name是需要查询的表名。如果需要查询所有字段,可以使用通配符*代替列名。 举个例子,假设我们有一个表格来记录学生的出席情况,其中包含列名:id, name和score,我们可以使用以下语句来选出不同分数的学生: SELECT DISTINCT score FROM table_name; 这样,我们就可以得到一个结果集包含所有不同的分数。 需要注意的是,使用DISTINCT会增加查询的时间和资源使用,因为数据库需要遍历整个表来确定不同的值。因此,在使用DISTINCT时需要谨慎考虑,尽量避免在大型数据库中使用它。 总之,DISTINCT是MySQL中去除重复数据的一种有力工具,可以帮助我们准确地选择需要的数据。通过合理的使用,我们可以从数据库中得到更有价值的信息,更好地支持我们的业务应用。 ### 回答3: MySQL 去除重复数据有多种方式,其中一种是使用 DISTINCT 关键字。DISTINCT 用于查询结果中去除重复的行,其语法规则如下: SELECT DISTINCT column1, column2, ... FROM table_name WHERE condition; 其中,column1, column2, ... 表示要查询的列名,table_name 表示要查询的表名,condition 表示查询的条件。 举个例子,如果要查询一张“学生信息表”中的所有班级名称,并去除重复的行,可以使用以下 SQL 语句: SELECT DISTINCT class FROM student_info; 在这个例子中,“学生信息表”中有多个班级,每个班级有多条记录。如果不使用 DISTINCT 关键字,那么查询结果中会出现多个重复的班级名称,使用 DISTINCT 关键字可以去除这些重复的行,只留下不同的班级名称。 需要注意的是,使用 DISTINCT 关键字会对查询性能产生一定的影响,因为 MySQL 在查询结果时需要去重,所以会增加一定的查询时间。在设计数据结构时应尽可能避免重复数据的出现,以提高查询性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值