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

MSSQL
保护SQL Server 2000的十个步骤
突破一流信息监控拦截系统进行SQL注射
Oracle8的不安全因素及几点说明
数据库安全性策略(1)
数据库安全性策略 (2)
浅谈数据库的攻击
SQL数据库的一些攻击
怎样使MySQL安全以对抗解密高手
不当编写SQL语句导致系统不安全
调整重心-从IIS到SQL Server数据库安全
SQL Server:安全设计从头起
保护SQL Server:为安全性而安装
网站入侵过程!
网管,你的防火墙上也有“洞”吗
跟我学SQL:(三)使用SQL子选择来合并查询
跟我学SQL:(四)查询多个表格
跟我学SQL:(五)创建和修改表格
跟我学SQL:(六)串行数据类型
跟我学SQL:(八)数值数据类型
跟我学SQL:(九)datetime和interval数据类型

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 87 ::
收藏到网摘: 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