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

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

每位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 ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATETABLE [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 ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE VIEW [dbo].[OrderDetailsSumByOrderID_vue]
AS
SELECT TOP 100 PERCENT OrderID,
SUM(ExtendedAmount) AS TotalAmount
FROM?dbo.OrderDetails_New
GROUP BY OrderID
ORDER BY OrderID

列表B

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

标签:
0
投稿

猜你喜欢

  • oracle 安装与SQLPLUS简单用法

    2009-06-10 17:49:00
  • CSS实例教程:复合型CSS条状图表(下)

    2010-01-23 12:52:00
  • 把你的数据库置于版本控制之下

    2009-04-25 10:01:00
  • asp如何分页显示数据库查询结果?

    2009-11-22 19:23:00
  • oracle join on 数据过滤问题

    2009-07-14 21:17:00
  • ASP+XML制作菜单管理

    2008-05-19 12:38:00
  • 给zblog加上运行代码功能

    2007-12-19 13:07:00
  • 用WEB(ASP)方式实现SQL SERVER 数据库的备份和恢复

    2010-05-11 20:12:00
  • javascript中类的创建和继承

    2008-05-08 12:07:00
  • Qzoneing主题视觉设计分享

    2009-07-21 18:12:00
  • ASP 使用jqGrid实现读写删的代码(json)

    2010-03-07 17:26:00
  • 每个分类取最新的几条的SQL实现代码

    2012-08-21 10:57:18
  • 超半数中文网页一年内将“消失”

    2008-03-08 12:49:00
  • Cookies 欺骗漏洞的防范方法(vbs+js 实现)

    2011-03-09 11:09:00
  • Script 元素 type 属性的妙用

    2011-03-07 16:13:00
  • Select下拉列表控件美化

    2008-11-12 12:55:00
  • [翻译]标记语言和样式手册 chapter 6 短语元素

    2008-01-25 16:37:00
  • asp如何验证信用卡是否可用?

    2010-06-10 18:39:00
  • 实用301转向到另一域名相应页面的asp代码

    2011-04-18 10:42:00
  • 用ASP和XMLHTTP分析远程XML文件

    2007-12-12 12:48:00
  • asp之家 网络编程 m.aspxhome.com