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的资料请关注脚本之家其它相关文章!

相关文章

  • MySQL 时间类型用 datetime, timestamp 还是 integer 更好

    MySQL 时间类型用 datetime, timestamp 还是 integer 更好

    这篇文章主要介绍了MySQL 时间类型用datetime,timestamp还是integer更好,文章通过围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-09-09
  • MYSQL where 1=1判定中的作用说明

    MYSQL where 1=1判定中的作用说明

    最近看到很多sql里用到where 1=1,原来觉得这没用嘛,但是又想到如果没用为什么要写呢?
    2011-09-09
  • mysql where中如何判断不为空的实现

    mysql where中如何判断不为空的实现

    本文主要介绍了mysql where中如何判断不为空的实现,本文将针对这些空演示如何判断是否为空,以及如何写sql过滤,包括使用判空函数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-03-03
  • MySQL中给定父行找到所有子行的解决方案

    MySQL中给定父行找到所有子行的解决方案

    这篇文章主要给大家介绍了关于MySQL中给定父行找到所有子行的解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • MySQL使用游标批量处理进行表操作

    MySQL使用游标批量处理进行表操作

    这篇文章主要介绍了MySQL使用游标批量进行表操作,包括批量添加索引、批量添加字段等,感兴趣的小伙伴们可以参考一下
    2016-03-03
  • Express连接MySQL及数据库连接池技术实例

    Express连接MySQL及数据库连接池技术实例

    数据库连接池是程序启动时建立足够数量的数据库连接对象,并将这些连接对象组成一个池,由程序动态地对池中的连接对象进行申请、使用和释放,本文重点给大家介绍Express连接MySQL及数据库连接池技术,感兴趣的朋友一起看看吧
    2022-02-02
  • MySQL 重命名表的操作方法及注意事项

    MySQL 重命名表的操作方法及注意事项

    有时候我们会遇到重命名表的需求,比如说因业务变化,需要将表 a 重命名为表 b 。这个时候可以执行 RENAME TABLE 语句或 ALTER TABLE 语句来重命名表。本篇文章我们一起来学习下重命名表相关知识。
    2021-05-05
  • MySQL批量SQL插入性能优化详解

    MySQL批量SQL插入性能优化详解

    这篇文章主要为大家详细介绍了MySQL批量SQL插入性能优化,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • Mysql体系化探讨令人头疼的JOIN运算

    Mysql体系化探讨令人头疼的JOIN运算

    这篇文章主要介绍了体系化探讨令人头疼的JOIN运算,本文将对JOIN运算进行体系化深入的探讨,根据自己工作经验及参考业界经典案例,针对性地提出语法简化和性能优化的方法论,需要的朋友可以参考下
    2022-07-07
  • MySQL多实例配置方案

    MySQL多实例配置方案

    MySQL多实例就是,在一台机器上开启多个不同的服务端口(如:3306,3307,3308...),运行多个MySQL服务进程,这些服务进程通过不同的socket监听不同的端口提供服务。
    2018-04-04

最新评论