如何在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
投稿

猜你喜欢

  • windows、linux下打包Python3程序详细方法

    2023-09-30 22:06:53
  • Scrapy爬虫实例讲解_校花网

    2023-03-02 14:46:39
  • 使用 Python 清理收藏夹里已失效的网站

    2023-01-11 01:26:00
  • SQL Server 2005 输入框不能输入中文问题

    2010-02-04 09:14:00
  • python爬虫库scrapy简单使用实例详解

    2022-03-22 23:46:11
  • 几个常用的js小函数

    2007-09-19 12:59:00
  • 在 CSS 中关于字体处理效果的思考

    2008-04-25 22:57:00
  • php cli换行示例

    2024-05-03 15:50:59
  • 用python制作游戏外 挂

    2023-08-03 15:55:43
  • MYSQL数据库常用命令集合

    2009-02-26 16:01:00
  • 利用python解决mysql视图导入导出依赖的问题

    2023-10-28 07:27:38
  • python库pydantic的简易入门教程

    2022-06-27 14:05:28
  • 兼容主流浏览器,纯CSS下拉菜单

    2010-09-05 20:30:00
  • mac系统OS X10.10版本安装最新5.7.9mysql的方法

    2024-01-14 10:05:38
  • Python中输入若干整数以逗号间隔实现统计每个整数出现次数

    2021-10-27 22:20:04
  • 使用go实现简易比特币区块链公链功能

    2024-04-28 09:18:20
  • Python运维开发之psutil库的使用详解

    2023-10-24 14:22:55
  • ORACLE 常用的SQL语法和数据对象

    2009-02-26 10:58:00
  • python中lambda函数 list comprehension 和 zip函数使用指南

    2021-08-28 22:16:21
  • 用uWSGI和Nginx部署Flask项目的方法示例

    2023-12-07 22:42:37
  • asp之家 网络编程 m.aspxhome.com