SQL HAVING子句在GROUP BY中的条件筛选灵活运用

 更新时间:2023年11月30日 09:44:10   作者:小万哥  
这篇文章主要为大家介绍了SQL HAVING子句在GROUP BY中的条件筛选灵活运用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

SQL HAVING子句

HAVING子句被添加到SQL中,因为WHERE关键字不能与聚合函数一起使用。

HAVING语法

SELECT column_name(s)
FROM table_name
WHERE condition
GROUP BY column_name(s)
HAVING condition
ORDER BY column_name(s);

演示数据库

以下是Northwind示例数据库中“Customers”表的一部分选择:

CustomerIDCustomerNameContactNameAddressCityPostalCodeCountry
1Alfreds FutterkisteMaria AndersObere Str. 57Berlin12209Germany
2Ana Trujillo Emparedados y heladosAna TrujilloAvda. de la Constitución 2222México D.F.05021Mexico
3Antonio Moreno TaqueríaAntonio MorenoMataderos 2312México D.F.05023Mexico
4Around the HornThomas Hardy120 Hanover Sq.LondonWA1 1DPUK
5Berglunds snabbköpChristina BerglundBerguvsvägen 8LuleåS-958 22Sweden

SQL HAVING示例

以下SQL语句列出了每个国家的客户数量。只包括拥有超过5名客户的国家:

SELECT COUNT(CustomerID), Country
FROM Customers
GROUP BY Country
HAVING COUNT(CustomerID) > 5;

以下SQL语句列出了每个国家的客户数量,按高到低排序(只包括拥有超过5名客户的国家):

SELECT COUNT(CustomerID), Country
FROM Customers
GROUP BY Country
HAVING COUNT(CustomerID) > 5
ORDER BY COUNT(CustomerID) DESC;

演示数据库

以下是Northwind示例数据库中“Orders”表的一部分选择:

OrderIDCustomerIDEmployeeIDOrderDateShipperID
102489051996-07-043
102498161996-07-051
102503441996-07-082

以及“Employees”表的一部分选择:

EmployeeIDLastNameFirstNameBirthDatePhotoNotes
1DavolioNancy1968-12-08EmpID1.picEducation includes a BA....
2FullerAndrew1952-02-19EmpID2.picAndrew received his BTS....
3LeverlingJanet1963-08-30EmpID3.picJanet has a BS degree....

更多HAVING示例

以下SQL语句列出了注册超过10个订单的员工:

SELECT Employees.LastName, COUNT(Orders.OrderID) AS NumberOfOrders
FROM (Orders
INNER JOIN Employees ON Orders.EmployeeID = Employees.EmployeeID)
GROUP BY LastName
HAVING COUNT(Orders.OrderID) > 10;

以下SQL语句列出了是否员工“Davolio”或“Fuller”注册了超过25个订单:

SELECT Employees.LastName, COUNT(Orders.OrderID) AS NumberOfOrders
FROM Orders
INNER JOIN Employees ON Orders.EmployeeID = Employees.EmployeeID
WHERE LastName = 'Davolio' OR LastName = 'Fuller'
GROUP BY LastName
HAVING COUNT(Orders.OrderID) > 25;

SQL EXISTS 运算符

EXISTS 运算符用于测试子查询中是否存在任何记录。如果子查询返回一个或多个记录,EXISTS 运算符将返回 TRUE

EXISTS 语法

SELECT column_name(s)
FROM table_name
WHERE EXISTS
(SELECT column_name FROM table_name WHERE condition);

演示数据库

以下是 Northwind 示例数据库中 "Products" 表的一部分选择:

ProductIDProductNameSupplierIDCategoryIDUnitPrice
1Chais1110 boxes x 20 bags18
2Chang1124 - 12 oz bottles19
3Aniseed Syrup1212 - 550 ml bottles10
4Chef Anton's Cajun Seasoning2248 - 6 oz jars22
5Chef Anton's Gumbo Mix2236 boxes21.35

以及 "Suppliers" 表的一部分选择:

SupplierIDSupplierNameContactNameAddressCityPostalCodeCountry
1Exotic LiquidCharlotte Cooper49 Gilbert St.LondonEC1 4SDUK
2New Orleans Cajun DelightsShelley BurkeP.O. Box 78934New Orleans70117USA
3Grandma Kelly's HomesteadRegina Murphy707 Oxford Rd.Ann Arbor48104USA
4Tokyo TradersYoshi Nagase9-8 Sekimai Musashino-shiTokyo100Japan

SQL EXISTS 示例

以下 SQL 语句返回 TRUE 并列出产品价格低于 20 的供应商:

SELECT SupplierName
FROM Suppliers
WHERE EXISTS (SELECT ProductName FROM Products WHERE Products.SupplierID = Suppliers.SupplierID AND Price < 20);

以下 SQL 语句返回 TRUE 并列出产品价格等于 22 的供应商:

SELECT SupplierName
FROM Suppliers
WHERE EXISTS (SELECT ProductName FROM Products WHERE Products.SupplierID = Suppliers.SupplierID AND Price = 22);

SQL ANY 和 ALL 运算符

ANY 和 ALL 运算符允许您在单个列值和一系列其他值之间进行比较。

SQL ANY 运算符

ANY 运算符返回布尔值作为结果,如果子查询值中的任何一个满足条件,则返回 TRUEANY 意味着如果对范围内的任何值进行操作为真,则条件将为真。

ANY 语法

SELECT column_name(s)
FROM table_name
WHERE column_name operator ANY
  (SELECT column_name
  FROM table_name
  WHERE condition);

注意:operator 必须是标准比较运算符(=、<>、!=、>、>=、< 或 <=)。

SQL ANY 示例

以下 SQL 语句列出了如果在 OrderDetails 表中找到任何记录的话,具有 Quantity 等于 10 的 ProductName(这将返回 TRUE,因为 Quantity 列有一些值为 10):

SELECT ProductName
FROM Products
WHERE ProductID = ANY
  (SELECT ProductID
  FROM OrderDetails
  WHERE Quantity = 10);

以下 SQL 语句列出了如果在 OrderDetails 表中找到任何记录的话,具有 Quantity 大于 99 的 ProductName(这将返回 TRUE,因为 Quantity 列有一些值大于 99):

SELECT ProductName
FROM Products
WHERE ProductID = ANY
  (SELECT ProductID
  FROM OrderDetails
  WHERE Quantity > 99);

以下 SQL 语句列出了如果在 OrderDetails 表中找到任何记录的话,具有 Quantity 大于 1000 的 ProductName(这将返回 FALSE,因为 Quantity 列没有任何值大于 1000):

SELECT ProductName
FROM Products
WHERE ProductID = ANY
  (SELECT ProductID
  FROM OrderDetails
  WHERE Quantity > 1000);

SQL ALL 运算符

ALL 运算符返回布尔值作为结果,如果子查询值中的所有值都满足条件,则返回 TRUEALL 意味着只有当范围内的所有值都为真时,条件才为真。

使用 SELECT 的 ALL 语法

SELECT ALL column_name(s)
FROM table_name
WHERE condition;

使用 WHERE 或 HAVING 的 ALL 语法

SELECT column_name(s)
FROM table_name
WHERE column_name operator ALL
  (SELECT column_name
  FROM table_name
  WHERE condition);

注意:operator 必须是标准比较运算符(=、<>、!=、>、>=、< 或 <=)。

SQL ALL 示例

以下 SQL 语句列出了所有的产品名称:

SELECT ALL ProductName
FROM Products
WHERE TRUE;

以下 SQL 语句列出了如果在 OrderDetails 表中的所有记录的话,具有 Quantity 等于 10 的 ProductName。这当然将返回 FALSE,因为 Quantity 列有许多不同的值(不仅仅是值为 10):

SELECT ProductName
FROM Products
WHERE ProductID = ALL
  (SELECT ProductID
  FROM OrderDetails
  WHERE Quantity = 10);

以上就是SQL HAVING子句在GROUP BY中的条件筛选灵活运用的详细内容,更多关于SQL HAVING条件筛选GROUP BY的资料请关注脚本之家其它相关文章!

相关文章

  • 利用Shell脚本实现远程MySQL自动查询

    利用Shell脚本实现远程MySQL自动查询

    本篇文章是对利用Shell脚本实现远程MySQL自动查询的方法进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • Spring中的InitializingBean和SmartInitializingSingleton的区别详解

    Spring中的InitializingBean和SmartInitializingSingleton的区别详解

    这篇文章主要介绍了Spring中的InitializingBean和SmartInitializingSingleton的区别详解,InitializingBean只有一个接口方法afterPropertiesSet(),在BeanFactory初始化完这个bean,并且把bean的参数都注入成功后调用一次afterPropertiesSet()方法,需要的朋友可以参考下
    2024-01-01
  • 揭开SQL中NULL的神秘面纱

    揭开SQL中NULL的神秘面纱

    表的字段默认允许存放NULL值,这意味着,您在插入记录或者更新记录时,可以不为该字段指定值,此时该字段将存储NULL值,这篇文章将揭开SQL中NULL的神秘面纱。这个问题可能困扰着很多初级开发者
    2023-01-01
  • MySQL字段类型全面解读

    MySQL字段类型全面解读

    这篇文章主要介绍了MySQL字段类型,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • centos7.2下安装mysql5.7数据库的命令详解

    centos7.2下安装mysql5.7数据库的命令详解

    这篇文章主要介绍了centos7.2下安装mysql5.7数据库,文中给出了所有的命令,按照命令执行就会安装上 ,需要的朋友可以参考下
    2019-07-07
  • MySQL之PXC集群搭建的方法步骤

    MySQL之PXC集群搭建的方法步骤

    PXC 是一套 MySQL 高可用集群解决方案,本文主要介绍了MySQL之PXC集群搭建的方法步骤,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-05-05
  • MySQL分页查询的三种常用方法

    MySQL分页查询的三种常用方法

    在处理数据库查询时,我们经常需要对结果进行分页,以便在用户界面上提供更好的浏览体验,本文主要介绍了MySQL分页查询的三种常用方法,具有一定的参考价值,感兴趣的可以了解一下
    2024-03-03
  • mysql installer web community 5.7.21.0.msi安装图文教程

    mysql installer web community 5.7.21.0.msi安装图文教程

    这篇文章主要为大家详细介绍了mysql installer web community 5.7.21.0.msi,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-09-09
  • SQLyog连接MySQL8.0+报错:错误码2058的解决方案

    SQLyog连接MySQL8.0+报错:错误码2058的解决方案

    使用sqlyog连接数据库过程中出现2058错误,出现的原因是因为MYSQL8.0对密码的加密方式进行了改变,这篇文章主要给大家介绍了关于SQLyog连接MySQL8.0+报错:错误码2058的解决方案,需要的朋友可以参考下
    2024-07-07
  • mysql主从服务器配置特殊问题

    mysql主从服务器配置特殊问题

    如果修改了主服务器的配置,记得删除从服务器上的master.info文件。否则从服务器使用的还是老配置,可能会导致错误。
    2010-12-12

最新评论