当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 在SQL Server中通过原子建立分子查询

MSSQL
获取MSSQL数据字典的SQL语句
Microsoft Search 服务无法启动 解决办法.
找出所有非xml索引并重新整理的sql
SQL Server提示"选定的用户拥有对象,所以无法除去该用户”
SQL Server"错误 21002: [SQL-DMO]用户 * 已经存在问题解决
删除重复记录,并且剩下一条
select * from sp_who的解决方案
Sql语句与存储过程查询数据的性能测试实现代码
MSSQL 游标使用 心得
SQL 时间类型的模糊查询
mssql 指定字段编号sql语句
sql server中的decimal或者numeric的精度问题
sql 数据库还原图文教程
存储过程解密(破解函数,过程,触发器,视图.仅限于SQLSERVER2000)
MSSQL SERVER中的BETWEEN AND的使用
SQL Server约束增强的两点建议
SQL Server 更改DB的Collation
Oracle 10g各个帐号的访问权限、登录路径、监控状态命令查询等等
SQL Server的复制功能
sql 普通行列转换

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 81 ::
收藏到网摘: n/a

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

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

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

我删除了复合主键,增加一个叫做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所示。

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