热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

用SQLServerHaving盘算列和均匀值

做为一名数据库语言和用法教师,我发明一些特别难以说明的主题。其中的一个主题为SQLServer的Having子句。在本文中,我将简略阐明这个子句,并供给一些代码实例,我想这是阐明Ha

做为一名数据库语言和用法教师,我发明一些特别难以说明的主题。其中的一个主题为SQL Server的Having子句。在本文中,我将简略阐明这个子句,并供给一些代码实例,我想这是阐明Having子句用法的最佳方法。

严格来说,Having并不需要一个子表,但没有子表的Having并没有实际意义。假如你只需要一个表,那么你可以用Where子句达到一切目标。为进行实践,Having预先假定至少两个表和一个基于第二个表的合计函数。

下面是一个简略的例子:你想要订单总数超过25000美元的客户清单。你需要适当连接的三个表:Customer、SalesOrderHeader和SalesOrderDetail。然后,你求Detail的和,并将总数与25000美元进行比拟。查看列表A。

查看列表A中的代码时,有一件事情并不明显,即LineTotal列被盘算。你可以像求实际的列的和一样求出已盘算列的和。但是,你不能在同一个把持中履行两个不同层次的合计函数。

以下为引用的内容:
SELECT
            Sales.Customer.CustomerID,
            Sales.SalesOrderHeader.SalesOrderID,
            SUM(Sales.SalesOrderDetail.LineTotal)
            AS SubTotalFROM
            Sales.Customer
            INNER JOIN Sales.SalesOrderHeader
            ON Sales.SalesOrderHeader.Customer
            ID = Sales.Customer.CustomerID
            INNER JOIN Sales.SalesOrderDetail
            ON Sales.SalesOrderDetail.SalesOrder
            ID = Sales.SalesOrderHeader.SalesOrderIDGROUP BY
            Sales.Customer.CustomerID,
            Sales.SalesOrderHeader.SalesOrder
            IDHAVING SUM(LineTotal) > 25000.00ORDER BY
            Sales.Customer.CustomerID,
            SalesOrderID ;
 
列表A

假设你盼看知道所有客户的均匀销售额。你可以应用列表B中的代码,它返回如下错误信息:

以下为引用的内容:
SELECT
            Sales.SalesOrderHeader.SalesOrderID,
            AVG(SUM(Sales.SalesOrderDetail.LineTotal))
            AS AverageFROM
            Sales.SalesOrderHeader
            INNER JOIN Sales.SalesOrderDetail
            ON Sales.SalesOrderDetail.SalesOrder
            ID = Sales.SalesOrderHeader.SalesOrder
            IDGROUP BY
            Sales.SalesOrderHeader.SalesOrderID
 
列表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
            ASBEGIN
            -- 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'

推荐阅读
  • Kafka 示例项目中 Log4j 的配置与调试
    本文详细介绍了如何在 Kafka 源码中的示例项目配置 Log4j,以确保能够正确记录日志信息,帮助开发者更好地理解和调试代码。 ... [详细]
  • 本文探讨了使用匈牙利算法解决二分图中的最大权匹配问题,并通过HDU1533题目实例进行详细解析。代码实现中包括了必要的数据结构定义、输入处理以及求解过程。 ... [详细]
  • Django框架的使用教程mysql数据库[三]
    Django的数据库1.在Django_test下的view.py里面model定义模型fromdjango.dbimportmodels#Createyourmodelshere ... [详细]
  • SQL注入实验:SqliLabs第38至45关解析
    本文深入探讨了SqliLabs项目中的第38至45关,重点讲解了堆叠注入(Stacked Queries)的应用技巧及防御策略。通过实际案例分析,帮助读者理解如何利用和防范此类SQL注入攻击。 ... [详细]
  • 本文详细解析了 Mongolass 中 populate 方法的正确使用方式及其限制,特别是与 Mongoose 在使用上的差异。 ... [详细]
  • Elasticsearch基础操作指南:使用Postman进行数据管理
    本文将介绍如何利用Postman工具执行基本的日志写入和数据管理操作。通过本教程,您将了解如何连接至Elasticsearch服务,创建索引,存储及检索数据。 ... [详细]
  • 统计报表模板及其实现方法
    本文介绍两个实用的统计报表模板,并提供如何将这些静态模板转换为动态JSP页面的方法。同时,文中附上了详细的代码示例。 ... [详细]
  • 解析骁龙660AIE与骁龙660的主要差异
    随着智能手机市场的不断发展,处理器技术也在不断进步。近期,一些手机开始采用骁龙660AIE处理器,这引发了消费者对其与标准版骁龙660之间差异的好奇。本文将详细探讨这两款处理器的区别,帮助您更好地了解它们各自的特点。 ... [详细]
  • 本文介绍了三款实用的Chrome插件:Gooreplacer用于加速访问依赖特定外部接口的网站;HTTP Request Blocker帮助过滤无法加载的图片请求;Browse Manager则能有效阻止恼人的弹出广告。通过合理配置这些工具,可以显著提升上网体验。 ... [详细]
  • POJ 3472 空心方格铺砖问题(高精度计算)
    题目描述:给定一个(n+1)×(n+1)的方格,其中包含一个(n-1)×(n-1)的空洞。使用1×2的砖块进行铺设,求解不同的铺设方案总数。 ... [详细]
  • 本文详细介绍了如何构建MongoDB的ReplSet复制集群,包括环境准备、配置文件设置以及初始化复制集群的具体步骤。 ... [详细]
  • Python3兼容性提升:Robot Framework与RIDE的最新进展
    本文介绍了Robot Framework,一个基于Python的自动化测试框架,以及其配套IDE RIDE的最新更新。随着Python3的广泛采用,RIDE终于实现了对Python3的支持,这为Robot Framework的用户带来了福音。 ... [详细]
  • Shiro功能拓展:登录失败重试次数限制
    本文详细介绍了如何在Apache Shiro框架中实现对用户登录失败重试次数的限制,通过自定义密码匹配器来增强系统的安全性。该方法不仅能够有效防止暴力破解攻击,还能确保合法用户的账户安全。 ... [详细]
  • 致信息安全爱好者的成长指南
    本文旨在为信息安全爱好者提供一份详尽的成长指南,涵盖从学习心态调整到具体技能提升的各个方面。 ... [详细]
  • 本文探讨了为何采用RESTful架构及其优势,特别是在现代Web应用开发中的重要性。通过前后端分离和统一接口设计,RESTful API能够提高开发效率,支持多种客户端,并简化维护。 ... [详细]
author-avatar
msf6688
PHP小白,请大神 们多多关照!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有