在SQL Server中通过原子建立分子查询

lirui10238

lirui10238

2016-01-29 15:49

在SQL Server中通过原子建立分子查询,在SQL Server中通过原子建立分子查询

每位SQL Server开发员都有自己的首选操作方法。我的方法叫做分子查询。这些是由原子查询组合起来的查询,通过它们我可以处理一个表格。将原子组合起来,可以建立分子。当然也会有限制(化学家所称的化合价),但一般来说,这个原理还是适用的。

在本文中,我将探讨这种策略的几种变化。我从最基本的内容开始(即最详细的内容),然后逐步深化。为让你了解这种方法的灵活性,我会在不同层次使用几种技巧。(警告:这并不是唯一的解决方法,我只是在讨论一些可行的选择。)

我从普遍使用的数据库Northwind开始(虽然为了保留原貌,我把它复制到Northwind_New中,实际这才是我使用的数据库。)在我的拷贝中,我做出这些重要的修改。

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/sqlserver/)

我删除了复合主键,增加一个叫做PK的新列,并将其设为Identity列。

我增加了一个称作ExtendedAmount的计算列。

USE [Northwind_New]GO/****** Object: Table [dbo].[OrderDetails_New] Script Date: 08/23/2006 16:15:42 ******/SET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOCREATETABLE [dbo].[OrderDetails_New]([OrderDetailID] [int] IDENTITY(1,1)NOTNULL,[OrderID] [int] NOTNULL, [ProductID] [int] NOTNULL, [UnitPrice] [money] NOTNULL,[Quantity] [smallint] NOTNULL,[Discount] [real] NOTNULL, [ExtendedAmount] AS([Quantity] * [UnitPrice] *(1 - [Discount])), CONSTRAINT [PK_OrderDetails_New] PRIMARYKEYCLUSTERED( [OrderDetailID] ASC)ON [PRIMARY])ON [PRIMARY]

清单A

清单A中包含建立这个新表格的新建(Create)语句。我用这个命令将它和值从原始表格中迅速移植出来:

INSERT INTO [Northwind_New].[dbo].[OrderDetails_New]SELECT * FROM [Northwind_New].[dbo].[Order Details]

既然我有一个多行的表格,是时候开始实验了。(一旦新列ExtendedAmount被计算,其值会自动移植。)最初,我想用OrderID计算ExtendedAmount列的总数。我建立一个视图,如清单B所示。

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/sqlserver/)

USE [Northwind_New]GO/****** Object:?View [dbo].[OrderDetailsSumByOrderID_vue]Script Date: 08/23/2006 16:31:18 ******/SET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOCREATE VIEW [dbo].[OrderDetailsSumByOrderID_vue]ASSELECT TOP 100 PERCENT OrderID, SUM(ExtendedAmount) AS TotalAmountFROM?dbo.OrderDetails_NewGROUP BY OrderIDORDER BY OrderID

清单B

我每行得到一个OrderID,ExtendedAmount的列数得到总计。(称之为OrderAmount,将航运,税收等相加得到OrderTotal)。

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

set ANSI_NULLS ONset QUOTED_IDENTIFIER ONgo-- =============================================-- Author:        Arthur Fu      
展开更多 50%)
分享

猜你喜欢

在SQL Server中通过原子建立分子查询

SQLServer
在SQL Server中通过原子建立分子查询

教你在SQL Server中由原子建立分子查询

SQLServer
教你在SQL Server中由原子建立分子查询

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

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

编程语言 网络编程
如何在SQL Server中由原子建立分子查询

通过非动态SQL语句在SQL Server中执行动态查询

编程语言 网络编程
通过非动态SQL语句在SQL Server中执行动态查询

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

T-SQL命令在SQL Server查询中的运用

编程语言 网络编程
T-SQL命令在SQL Server查询中的运用

在SQL Server 2005中查询表结构及索引

SQLServer
在SQL Server 2005中查询表结构及索引

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

在SQL Server中编写通用数据访问方法

在SQL Server中编写通用数据访问方法

SQL Server数据库安全管理机制详解

SQL Server数据库安全管理机制详解
下拉加载更多内容 ↓