如何在SQL Server中由原子建立分子查询(2)

作者:Arthur Fuller 时间:2009-01-20 16:01:00 

我会在等式中引入一个表格UDF,如列表C所示。注意,我可以用两种方法调用函数:提交CustomerID将表格限定为那个顾客的订单,或提交一个NULL获得所有顾客订单列表。如果我提交CustomerID,那么订单列表就出现在OrderDate中;如果我提交NULL,列表就被分组并在CustomerID中由OrderDate排序。

set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
go

-- =============================================
-- Author:        Arthur Fuller
-- Create date: 23 Aug 2006
-- Description:   Table UDF to return Order Totals by Customer
-- Example: SELECT * FROM dbo.CustomerOrderTotals_fnt('VINET')
-- Example: SELECT * FROM dbo.CustomerOrderTotals_fnt(NULL)
-- Notes:       This udf is designed to serve two
-- purposes. Pass a CustomerID to limit the rows to
-- that customer, or pass nothing to get all customers
-- =============================================
ALTERFUNCTION [dbo].[CustomerOrderTotals_fnt]
(    
      -- Add the parameters for the function here
      @CustomerID varchar(5)=NULL
)
RETURNS TABLE
AS
RETURN
    (
      -- Add the SELECT statement with parameter references here
    SELECTTOP 100 PERCENT
        dbo.Customers.CustomerID,
        dbo.Customers.CompanyName,
        dbo.Orders.OrderID,
        dbo.Orders.OrderDate,
        dbo.OrderDetailsSumByOrderID_vue.TotalAmount
    FROM  
        dbo.Customers
    INNERJOIN
        dbo.Orders ON dbo.Customers.CustomerID = dbo.Orders.CustomerID
    INNERJOIN
        dbo.OrderDetailsSumByOrderID_vue
        ON dbo.Orders.OrderID = dbo.OrderDetailsSumByOrderID_vue.OrderID
    WHERE 
        dbo.Customers.CustomerID = @CustomerID
        OR @CustomerID ISNULL
    ORDERBY dbo.Orders.OrderDate
    )

--try it with these:
--SELECT * FROM dbo.CustomerOrderTotals_fnt('VINET')
--SELECT * FROM dbo.CustomerOrderTotals_fnt(NULL)
 
列表C

-- ================================================
-- Template generated from Template Explorer using:
-- Create Inline Function (New Menu).SQL
--
-- Use the Specify Values for Template Parameters
-- command (Ctrl-Shift-M) to fill in the parameter
-- values below.
--
-- This block of comments will not be included in
-- the definition of the function.
-- ================================================
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:        Arthur Fuller
-- Create date: 23 Aug 2006
-- Description:   Return total sales by Customer
-- Example:
--  SELECT CustomerID, CustomerTotal
--      FROM DBO.CustomerGrandTotal_fnt(null)
--  SELECT CustomerID, CustomerTotal
--      FROM DBO.CustomerGrandTotal_fnt('VINET')
--  SELECT CustomerID, CustomerTotal
--      FROM DBO.CustomerGrandTotal_fnt('VINET')
-- =============================================
CREATEFUNCTION CustomerGrandTotal_fnt
(    
      @CustomerID varchar(5)
)
RETURNS TABLE
AS
RETURN
(
      -- Add the SELECT statement with parameter references here
    SELECTTOP 100 PERCENT
        CustomerID,
        SUM(TotalAmount)AS CustomerTotal
    FROM dbo.CustomerOrderTotals_fnt(@CustomerID)
    WHERE dbo.CustomerOrderTotals_fnt.CustomerID = @CustomerID
        OR @CustomerID ISNULL
    GROUPBY CustomerID
    ORDERBY CustomerID

)
GO

 
列表D

更深入一步,我每个顾客打印一行,用一列显示每名顾客的总销售额。查看列表D。并不是所有项目都得到组合。在最外层,我能够以两种方式调用这个函数:提交合法CustomerID或UNLL。以下是它们各自的实例:

SELECT CustomerID, CustomerTotal

FROM DBO.CustomerGrandTotal_fnt(null)

SELECT CustomerID, CustomerTotal

FROM DBO.CustomerGrandTotal_fnt('VINET')

现在你有了一组精确的工具来帮助你挖掘适当层次的细节。计算列OrderDetails.ExtendedAmount隐藏了一个复杂层次,从那我又深入到我希望隐藏的细节。这就是我把这些对象叫做原子和分子查询的原因。我使用“查询”一词来概括这样一个事实,即讨论的对象是视图还是表格UDF并不重要。(虽然由于命名规则,suffix _fnt表示一个表格UDF,而suffix _vue表示一个视图。)

必须承认,Northwind数据库中没有大量的行,但我认为这种技巧可以得到很好地扩充。更为重要的是,我喜欢它提供的粒度。我能够做我想做的,并按要求重新使用或重新组合原子。

标签:
0
投稿

猜你喜欢

  • Python的getattr函数方法学习使用示例

    2021-10-18 13:43:25
  • 浅谈Python中os模块及shutil模块的常规操作

    2022-05-02 21:42:50
  • Python使用Dijkstra算法实现求解图中最短路径距离问题详解

    2022-07-31 02:40:33
  • PHP实现通过正则表达式替换回调的内容标签

    2024-05-13 09:25:39
  • 优化MySQL的数据库性能的八种方法

    2012-01-05 19:28:53
  • sql exist的妙用

    2007-11-08 11:47:00
  • 深入了解Python 变量作用域

    2023-06-08 10:01:15
  • PHP中类静态调用和范围解析操作符的区别解析

    2023-11-15 07:38:39
  • 如何获取浏览器的更多信息?

    2009-11-23 20:48:00
  • Windows安装Anaconda并且配置国内镜像的详细教程

    2023-07-06 13:45:15
  • Windows 下更改 jupyterlab 默认启动位置的教程详解

    2023-06-11 13:10:12
  • Python多线程即相关理念详解

    2021-12-07 12:04:47
  • 详解MySQL如何有效的存储IP地址及字符串IP和数值之间如何转换

    2024-01-28 11:10:41
  • 人性化网页设计技巧

    2007-10-15 13:02:00
  • javascript 跳转代码集合

    2024-04-19 10:42:40
  • javascript游戏开发之《三国志曹操传》零部件开发(一)让静态人物动起来

    2024-04-10 13:58:29
  • [翻译]标记语言和样式手册 Chapter 7 锚点

    2008-01-28 14:01:00
  • SQL Server的怪辟:异常与孤立事务

    2009-09-24 14:11:00
  • 10条改进你的CSS代码的方法

    2010-03-20 22:07:00
  • 解析JavaScript中 querySelector 与 getElementById 方法的区别

    2024-04-19 09:57:32
  • asp之家 网络编程 m.aspxhome.com