用SQL Server HAVING子句计算列和平均值
2025-10-29 18:30:32阅读量:0 字体:大 中 小
在本文中,简单说明这个子句,并提供一些代码实例,这是说明HAVING子句用法的最佳方法。
严格来说,HAVING并不需要一个子表,但没有子表的HAVING并没有实际意义。假如你只需要一个表,那么你可以用WHERE子句达到一切目的。为进行实践,HAVING预先假定至少两个表和一个基于第二个表的合计函数。
下面是一个简单的例子:你想要订单总数超过25000美元的客户清单。你需要适当连接的三个表:Customer、SalesOrderHeader和SalesOrderDetail。然后,你求Detail的和,并将总数与25000美元进行比较。查看下面的列表A。
SELECTSales.Customer.CustomerID,
Sales.SalesOrderHeader.SalesOrderID,
SUM(Sales.SalesOrderDetail.LineTotal) AS SubTotal
FROM
Sales.Customer
INNER JOIN Sales.SalesOrderHeader
ON Sales.SalesOrderHeader.CustomerID = Sales.Customer.CustomerID
INNER JOIN Sales.SalesOrderDetail
ON Sales.SalesOrderDetail.SalesOrderID = Sales.SalesOrderHeader.SalesOrderID
GROUP BY
Sales.Customer.CustomerID,
Sales.SalesOrderHeader.SalesOrderID
HAVING SUM(LineTotal) > 25000.00
ORDER BY
Sales.Customer.CustomerID,
SalesOrderID ;
列表A
查看列表A中的代码时,有一件事情并不明显,即LineTotal列被计算。你可以像求实际的列的和一样求出已计算列的和。但是,你不能在同一个操作中执行两个不同层次的合计函数。
SELECTSales.SalesOrderHeader.SalesOrderID,
AVG(SUM(Sales.SalesOrderDetail.LineTotal)) AS Average
FROM
Sales.SalesOrderHeader
INNER JOIN Sales.SalesOrderDetail
ON Sales.SalesOrderDetail.SalesOrderID = Sales.SalesOrderHeader.SalesOrderID
GROUP BY
Sales.SalesOrderHeader.SalesOrderID
列表B
假设你希望知道所有客户的平均销售额。你可以使用列表B中的代码,它返回如下错误信息:
Msg 130, Level 15, State 1, Line 1
Cannot perform an aggregate function on an expression
containing an aggregate or a subquery.
你可以将平均值的计算过程进行分解来解决这个问题。你可以将第一部分(SUM)编写成一个表值UDF,如列表C所示。你可以根据列表D中的函数计算平均值。列表E说明你如何能够进行组合。
USE [AdventureWorks]GO/****** Object: UserDefinedFunction [dbo].[SalesTotals_fnt] Script Date: 12/09/2006 11:32:54 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE FUNCTION [dbo].[SalesTotals_fnt]()
RETURNS TABLE
AS RETURN
(SELECT SalesOrderID, SUM(LineTotal)AS TotalSale
FROM Sales.SalesOrderDetail
GROUP BY Sales.SalesOrderDetail.SalesOrderID)
列表C
CREATE FUNCTION [dbo].[AverageSale_fns](
-- Add the parameters for the function here
--
)
RETURNS money
AS
BEGIN
-- Declare the return variable here
DECLARE @Result money
-- Add the T-SQL statements to compute the return value here
SET @Result =(SELECTAvg(TotalSale)AS AverageSale
FROM dbo.SalesTotals_fnt())
-- Return the result of the function
RETURN @Result
END
列表D
DECLARE @Avg moneySELECT @Avg = dbo.AverageSale_fns()
SELECT
*, @Avg as Average,
TotalSale / @Avg as Ratio,
CASE
WHEN TotalSale / @Avg > 1 THEN ’Above Average’
WHEN TotalSale / @Avg < 1 THEN ’Below Average’
ELSE ’Average’
END
FROM dbo.SalesTotals_fnt()
列表E
现在你知道了如何根据一个子表使用HAVING子句来测试合计值。当你需要在一个查询中使用两个不同的合计函数时,最好是把它们分解成单独的函数,然后再进行组合(如前一个例子所说明的)。
与典型编程一样,使每个函数专注于一件事情。然后,你就可以应用它们,并可不断重复应用。
免责声明:
本文《用SQL Server HAVING子句计算列和平均值》版权归原作者所有,内容不代表本站立场!
如本文内容影响到您的合法权益(含文章中内容、图片等),请及时联系本站,我们会及时删除处理。
推荐阅读

Xociety启动NFT质押系统!首两周代币NTx两倍送
50k数字认知网 - 区块链数字货币实时行情平台链游板块经历了牛熊市的洗礼后仍持续发展,并在今年成为加密社群瞩目的焦点。代表性的代币如YGG、GALA、MBOX今年以来的表现都相当不错。50k数字认知...
阅读: 26

胖企鹅NFT蹭LayerZero空投!但代币分配提案引起社群极大反弹
QWI数字认知网 - 区块链数字货币实时行情平台全链互操作协议LayerZero即将空投,超过数千个围绕LayerZero构建的项目正申请配合其代币分配,其中就包含知名蓝筹NFT项目胖企鹅(Pudgy...
阅读: 57

引领加密潮流!英国将发行官方NFT 稳定币纳入支付框架
6i7数字认知网 - 区块链数字货币实时行情平台根据《CNBC》报导,英国政府宣布将铸造非同质化代币(NFT),希望英国能在加密货币领域成为世界领导者。英国财政部经济事务秘书John Glen在一场金...
阅读: 47

Web3游戏王来袭? Konami合作AVAX开发商Ava Labs推NFT平台Resella
OJD数字认知网 - 区块链数字货币实时行情平台天本游戏巨头Konami Digital Entertainment(下称Konami),在2023年9月的东京电玩展(TGS2023)上,宣布将推出N...
阅读: 52

数字艺术家Beeple将举办Pepe艺术展!提交作品有望获得免费门票
MF1数字认知网 - 区块链数字货币实时行情平台美国知名数字艺术家Beeple,将在8月10日于南卡罗来纳州的Charleston举办Pepe艺术展!并公开募集艺术品,入选者将可获得活动免费门票!MF...
阅读: 63

OpenSea要求美国SEC厘清:NFT市场不是交易所或经纪商
mnn数字认知网 - 区块链数字货币实时行情平台美国NFT龙头平台OpenSea正式向监管机关喊话,要求美国证管会(SEC)明确表态:NFT市场不应被纳入 联邦证券法中的「交易所」或「经纪商」定义范畴...
阅读: 30

一文了解Ubisoft搞NFT、链游失败?分割旗下刺客信条三大IP设子公司 腾讯入股12.5亿美
Kkh数字认知网 - 区块链数字货币实时行情平台加拿大游戏大厂育碧Ubisoft今(28)宣布成立专责《刺客信条》、《极地战嚎》、《虹彩六号》三大新子公司,目的是为了获取由腾讯腾讯11.6亿欧元巨额投...
阅读: 64

美国司法部深入调查泰达币:1:1美元储备再遭质疑,投资者如何避险?
数字认知网报道:u7n数字认知网 - 区块链数字货币实时行情平台近期,美国司法部对泰达币展开了深入调查,这一消息在加密货币市场引起了轩然大波。泰达币作为全球最大的稳定币之一,一直宣称与美元保持1:1的...
阅读: 34

2024年十大泰达币骗局揭秘:十万元血本无归背后隐藏哪些陷阱?
数字认知网报道:lym数字认知网 - 区块链数字货币实时行情平台在2024年的加密货币市场中,泰达币骗局呈现出愈演愈烈的态势。随着加密货币的热度不断攀升,越来越多的投资者将目光投向了泰达币。然而,不法...
阅读: 38

泰达币再陷信任危机:最新法律调查与储备金透明度报告深度解析
数字认知网报道:vLN数字认知网 - 区块链数字货币实时行情平台泰达币再陷信任危机:最新法律调查与储备金透明度报告深度解析泰达币(USDT)作为加密货币市场中颇具影响力的稳定币,长期以来在市场交易中扮...
阅读: 54
猜你喜欢

“比特币永不关闭”照片:美国财政部长纪念周年,抨击民主党人
2025-11-04

据报道,政府因男子拖欠水费(他对此毫不知情)而查封并出售其价值90万美元的房产。
2025-11-04

今日比特币新闻:美联储降息引发谨慎情绪,比特币价格徘徊在悬崖边缘
2025-11-04

释放数据价值:从资源到要素再到生产力的全链路变革
2025-11-04

稳定币目前占据加密协议收入的75%,超过所有其他领域。
2025-11-04

Cardano面临巨大的抛售压力——以下是ADA可能很快站稳脚跟的原因
2025-11-04

今日比特币新闻:“11月加密货币熔炉:利好因素与监管和贸易风险发生冲突”
2025-11-04

比特币 (BTC) 不敌“Uptober”,下跌 3.93%
2025-11-04

新罕布什尔州因公众担忧而搁置加密货币挖矿法案
2025-11-04
