用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > sqlserver教程

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

时间:2014-11-30  来源:互联网  作者:佚名

每位SQL(SQL Server培训 mySQL培训 ) 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)。

来顶一下
返回首页
返回首页
推荐资讯
从零开始学ASP.NET-基础篇第1/7页 从零开始学ASP.NET-基础篇第1/7页第一天 学习目的: 掌握最基本的Label、TextBox、Button控件
ASP.NET入门数据篇 ASP.NET入门数据篇对于网站编程的初学者来说,总是会上网找些源码来看,但久而
相关文章
栏目更新
栏目热门