通过SQL Server原子来建立分子查询实操

以下的文章主要是介绍如何正确通过SQL Server原子来建立分子查询的实际操作过程,我们大家都知道每位SQL Server数据库的开发员都有自己独特的首选操作方法。我的方法叫做分子查询。

这些是由SQL Server原子查询组合起来的查询,通过它们我可以处理一个表格。将原子组合起来,可以建立分子。当然也会有限制(化学家所称的化合价),但一般来说,这个原理还是适用的。

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

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

我删除了复合主键,增加一个叫做PK的新列,并将其设为Identity列。

我增加了一个称作ExtendedAmount的计算列。

 

  1. USE [Northwind_New] GO /****** Object: Table [dbo].[OrderDetails_New] Script Date: 08/23/2006 16:15:42 ******/ SET ANSI_NULLS>  

清单A

清单A中包含SQL Server原子建立这个新表格的新建(Create)语句。我用这个命令将它和值从原始表格中迅速移植出来:

 

  1. INSERT INTO [Northwind_New].[dbo].[OrderDetails_New] SELECT * FROM [Northwind_New].[dbo].[Order Details] 

既然我有一个多行的表格,是时候开始实验了。(一旦新列ExtendedAmount被计算,其值会自动移植。)最初,我想用OrderID计算ExtendedAmount列的总数。我建立一个视图,如清单B所示。

 

  1. USE [Northwind_New] GO /****** Object:?View [dbo]. [OrderDetailsSumByOrderID_vue]Script Date: 08/23/2006 16:31:18 ******/ SET ANSI_NULLS>  

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

 

我会在等式中引入一个表格UDF,如清单C所示。注意,我可以用两种方法调用函数:提交CustomerID将表格限定为那个顾客的订单,或提交一个NULL获得所有顾客订单清单。如果我提交CustomerID,那么订单清单就出现在OrderDate中;如果我提交NULL,清单就被分组并在CustomerID中由OrderDate排序。

 

  1. set ANSI_NULLS>  

清单C

  1. -- ================================================ --   
  2. Template generated from Template Explorer using: -- Create Inline Function (New Menu).  
  3. SQL -- -- Use the Specify Values for Template Parameters -- command (Ctrl-Shift-M) to fill in the parameter  
  4. -- values below. -- -- This block of comments will not be included in -- the definition of the function.  
  5. -- ================================================ SET ANSI_NULLS>   

清单D

更深入一步,我每个顾客打印一行,用一列显示每名顾客的总销售额。查看清单D。并不是所有项目都得到组合。在最外层,我能够以两种方式调用这个函数:提交合法CustomerID或UNLL以下是它们各自的实例:

 

  1. SELECT CustomerID, CustomerTotal FROM DBO.CustomerGrandTotal_fnt(null) SELECT CustomerID, CustomerTotal FROM DBO.CustomerGrandTotal_fnt('VINET') 

现在你有了一组精确的工具来帮助你挖掘适当层次的细节。计算列OrderDetails.ExtendedAmount隐藏了一个复杂层次,从那我又深入到我希望隐藏的细节。这就是我把这些对象叫做SQL Server原子和分子查询的原因。我使用“查询”一词来概括这样一个事实,即讨论的对象是视图还是表格UDF并不重要。(虽然由于命名规则,suffix _fnt表示一个表格UDF,而suffix _vue表示一个视图。)

必须承认,Northwind数据库中没有大量的行,但我认为这种技巧可以得到很好地扩充。更为重要的是,我喜欢它提供的粒度。我能够做我想做的,并按要求重新使用或重新组合SQL Server原子。

【编辑推荐】

  1. SQL Server 2005 数据库镜像的运行方式
  2. 产生SQL Server死锁的原因与破解
  3. SQL Server备份文件中对现存数据库的导入
  4. 改善SQL Server安全规划的6步骤
  5. SQL Server 2000文件损坏的修复方案

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/300367.html<

(0)
运维的头像运维
上一篇2025-05-23 20:20
下一篇 2025-05-23 20:21

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注