百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

10 个 T-SQL 提示和技巧(关于提示词的三段式技巧,以下哪一项不属三段式要求)

liuian 2025-04-05 20:08 34 浏览


概述:.NET 和 T-SQL 共享一种明确无误的纽带。从我记事起,我就一直使用 T-SQL 以及 C# 和 Entity Framework Core。然而,在所有这些抽象之下,人们很容易忽视原始SQL的细微差别以及深入理解它的重要性。因此,让我们深入了解一些 RAW SQL :)1. 通用表表达式 (CTE)有没有发现自己迷失在子查询的海洋中?CTE 可以成为救命稻草。它们允许您命名临时结果集,并在主查询中使用它。以下是如何使用它:WITH Sales_CTE AS ( SELECT CustomerID, SUM(OrderTotal) AS TotalSales FROM Ord

.NET 和 T-SQL 共享一种明确无误的纽带。从我记事起,我就一直使用 T-SQL 以及 C# 和 Entity Framework Core。

然而,在所有这些抽象之下,人们很容易忽视原始SQL的细微差别以及深入理解它的重要性。

因此,让我们深入了解一些 RAW SQL :)

1. 通用表表达式 (CTE)

有没有发现自己迷失在子查询的海洋中?CTE 可以成为救命稻草。它们允许您命名临时结果集,并在主查询中使用它。以下是如何使用它:

WITH Sales_CTE AS (  
  SELECT CustomerID, SUM(OrderTotal) AS TotalSales  
  FROM Orders  
  GROUP BY CustomerID  
)  
SELECT *  
FROM Sales_CTE  
WHERE TotalSales > 1000;

2. 窗口函数

从新的角度看待数据。

窗口函数允许您通过“窗口”查看数据并跨相关行执行计算。考虑计算运行总数或对项目进行排名。

SELECT   
  CustomerID,   
  OrderDate,   
  OrderTotal,   
  SUM(OrderTotal) OVER (ORDER BY OrderDate) AS RunningTotal  
FROM Orders;

3. 表变量和临时表

有时,您需要一个临时位置来存储查询中的数据。

表变量和临时表非常适合此目的。它们就像您在重新整理房间时使用的临时储物箱。

DECLARE @TempTable TABLE (CustomerID INT, TotalSales MONEY);  
INSERT INTO @TempTable (CustomerID, TotalSales)  
  SELECT CustomerID, SUM(OrderTotal)  
  FROM Orders  
  GROUP BY CustomerID;

4. 索引:使查询运行速度更快。

如果您的查询速度很慢,索引可能正是您需要的提升。它们就像帮助 SQL Server 更快地查找数据的快捷方式。但请记住,太多会减慢数据更新速度,所以这完全是关于平衡的。

有几种类型的索引,但让我们保持简单,并讨论您可能会使用的两种主要索引:

聚簇索引

将聚集索引视为组织数据的主要方式。它实际上按索引的顺序存储行数据。因此,当您在列上创建聚集索引时,SQL Server 会根据该列的值重新排列表中的数据。

下面是一个基本示例:

CREATE CLUSTERED INDEX IX_YourTable_YourColumn  
ON YourTable(YourColumn);

非聚集索引

这些类似于附加指南,可帮助您根据您可能经常查询但不是主要排序机制的其他列查找数据。

与聚集索引不同,非聚集索引维护与实际表数据不同的结构,其中包括索引列和指向包含这些值的行的指针。

以下是您可以创建一个的方法:

CREATE NONCLUSTERED INDEX IX_YourTable_AnotherColumn  
ON YourTable(AnotherColumn);

为什么要关心索引?

好吧,如果没有它们,SQL Server 必须扫描整个表才能找到您要求的数据,这可能会很慢且很痛苦,尤其是对于大型表。使用索引,它可以快速跳转到表的右侧并获取所需的内容。

但是,要注意的是

虽然索引非常适合读取操作,但它们会减慢 INSERT、UPDATE 和 DELETE 等写入操作的速度,因为每次数据更改时都需要更新索引本身。这一切都是为了根据应用程序使用数据的方式找到正确的平衡点。

5. MERGE 语句

MERGE 语句是 SQL Server 中的一个强大工具。

它允许您更新现有记录、插入新记录或删除不再需要的记录,所有这些都只需一个命令即可完成。您可以设置如何在两个表之间匹配数据的规则,其余的由 MERGE 负责。

这使得使表保持最新变得更加容易,尤其是在处理大量更改时。

MERGE INTO Customers AS target  
USING UpdatedCustomers AS source  
ON target.CustomerID = source.CustomerID  
WHEN MATCHED THEN  
  UPDATE SET target.ContactName = source.ContactName  
WHEN NOT MATCHED BY TARGET THEN  
  INSERT (CustomerID, ContactName)  
  VALUES (source.CustomerID, source.ContactName)  
WHEN NOT MATCHED BY SOURCE THEN  
  DELETE;

6. TRY_CAST和TRY_CONVERT:避免转换问题。

当您从不同位置提取数据或使用用户输入时,有时事情并不完全匹配。这就是TRY_CAST和TRY_CONVERT派上用场的地方。

这两个函数都尝试将值的数据类型更改为另一种类型。如果转换是可能的,那就太好了!它们以新格式返回值。

但是,如果无法完成转换(可能是因为数据的格式意外),则它们将返回 NULL 而不是抛出错误。这非常有用,因为这意味着即使数据出现问题,您的查询也能保持平稳运行。

TRY_CAST

假设您有一列应该是日期,但有可能有一些非日期值潜入其中。

SELECT TRY_CAST(YourColumn AS DATE) FROM YourTable;

如果包含不是日期的内容,TRY_CAST 将为该值返回 NULL,而不是因错误而停止查询。YourColumn

TRY_CONVERT

与 TRY_CAST 非常相似,但它允许您指定转换的样式。这对于格式可能发生变化的日期和时间特别有用。

SELECT TRY_CONVERT(DATE, YourColumn, 101) FROM YourTable;

这将尝试使用样式“101”(美国样式,mm/dd/yyyy)转换为 DATE。如果转换不起作用,则会收到 NULL 而不是错误。YourColumn

7. SET NOCOUNT ON:跳过不必要的信息。

在 SQL 脚本或存储过程中打开就像告诉 SQL Server,“嘿,让我们保持聊天最少。SET NOCOUNT ON

通常,SQL Server 喜欢在每次运行 INSERT、UPDATE、DELETE 或 SELECT 语句时通过说明受影响的行数来提醒您一些提示。此消息乍一看似乎很有帮助,但是当您运行大量语句或处理复杂的过程时,所有这些更新都会减慢速度。

性能提升

特别是在复杂的程序中或进行大量小操作时,删除这些消息可以稍微加快速度。它可以减少 SQL Server 和应用程序之间的网络流量,这在高容量环境中特别有用。

更干净的应用程序日志

如果您的应用程序或工具记录了这些消息,则关闭它们可以使您的日志更干净,并更专注于重要的事情。

这是你如何做到的:

SET NOCOUNT ON;  
-- Your T-SQL code goes here

只需将此行放在脚本或存储过程的开头即可。这是一个很小的改变,但可以在保持事情顺利进行和专注于重要的事情方面产生很大的影响。

请记住,仅影响有关受影响行的消息;它不会使错误消息或其他重要信息静音,因此您仍然可以了解引擎盖下发生的事情。SET NOCOUNT ON

8. 动态 SQL:当您需要灵活性时。

动态 SQL 允许您动态构建 SQL 语句。这就像能够根据您目前拥有的零件(数据)随心所欲地组装您的乐高套装。

DECLARE @Table NVARCHAR(100) = N'Customers';  
EXECUTE sp_executesql N'SELECT * FROM ' + @Table;

9. OUTPUT 条款:密切关注变化。

当您执行更改数据的操作时,OUTPUT 子句可以准确地显示所做的更改。

它可以告诉您添加、更新或删除了哪些行,甚至可以显示更新之前和之后的值。

下面是一个基本示例,用于说明如何将其与 INSERT 操作一起使用:

INSERT INTO Employees (Name, Role)  
OUTPUT inserted.EmployeeID, inserted.Name, inserted.Role  
VALUES ('Jane Doe', 'Developer');

在这种情况下,OUTPUT 子句指示 SQL Server 返回刚刚添加的新记录的 EmployeeID、Name 和 Role。对于 UPDATE 或 DELETE 操作,同样可以使用来查看新值或查看已删除的内容。inserteddeleted

这为您提供了一种强大的方法来审核更改,甚至将这些更改馈送到另一个进程或表中。

考虑一个场景,其中你正在更新员工记录,并希望保留更改日志:

UPDATE Employees  
SET Role = 'Senior Developer'  
OUTPUT deleted.EmployeeID, deleted.Role AS OldRole, inserted.Role AS NewRole  
INTO EmployeeRoleChanges (EmployeeID, OldRole, NewRole)  
WHERE EmployeeID = 1;

这不仅会更新员工的角色,还会捕获更改并将其记录到表中,显示旧角色、新角色以及角色已更改的员工的 ID。EmployeeRoleChanges

10. 在游标上选择基于 SET 的操作。

SQL Server 中的游标允许您一次处理一行。

这在某些情况下非常有用,因为您需要对每一行执行复杂的逻辑。但是,游标通常速度较慢,因为它们将一个可能是单个快速操作的过程转换为一长串步骤。

想象一下,你正在分发传单。您可以一次将它们分发给房间里的每个人(基于 SET 的操作),或者您可以走到每个人面前,一次递给他们一张传单(光标)。第一种方法显然要快得多。

另一方面,基于 SET 的操作可以同时处理整个数据集。SQL Server 的设计非常擅长于此。

假设您要更新表中某些行的列。使用光标,您可以编写如下内容(为清楚起见,请简化):

DECLARE @ID INT, @Value VARCHAR(100)  
DECLARE myCursor CURSOR FOR  
SELECT ID, Value FROM MyTable WHERE Condition = 'Yes'  

OPEN myCursor  
FETCH NEXT FROM myCursor INTO @ID, @Value  
  
WHILE @@FETCH\_STATUS = 0  
BEGIN  
    UPDATE MyTable SET AnotherColumn = @Value WHERE ID = @ID  
    FETCH NEXT FROM myCursor INTO @ID, @Value  
END  
  
CLOSE myCursor  
DEALLOCATE myCursor

使用基于 SET 的方法,您可以以更简单、更快速的方式获得相同的结果:

UPDATE MyTable  
SET AnotherColumn = Value  
WHERE Condition = 'Yes'

在这种情况下,基于 SET 的操作不仅更易于读取和写入,而且速度可能更快。

SQL Server 在处理数据集时可以利用索引、并行处理和其他优化,而不是单独处理每一行。

相关推荐

搭建一个20人的办公网络(适用于20多人的小型办公网络环境)

楼主有5台机上网,则需要一个8口路由器,组网方法如下:设备:1、8口路由器一台,其中8口为LAN(局域网)端口,一个WAN(广域网)端口,价格100--400元2、网线N米,这个你自己会看了:)...

笔记本电脑各种参数介绍(笔记本电脑各项参数新手普及知识)

1、CPU:这个主要取决于频率和二级缓存,频率越高、二级缓存越大,速度越快,现在的CPU有三级缓存、四级缓存等,都影响相应速度。2、内存:内存的存取速度取决于接口、颗粒数量多少与储存大小,一般来说,内...

汉字上面带拼音输入法下载(字上面带拼音的输入法是哪个)

使用手机上的拼音输入法打成汉字的方法如下:1.打开手机上的拼音输入法,在输入框中输入汉字的拼音,例如“nihao”。2.根据输入法提示的候选词,选择正确的汉字。例如,如果输入“nihao”,输...

xpsp3安装版系统下载(windowsxpsp3安装教程)

xpsp3纯净版在采用微软封装部署技术的基础上,结合作者的实际工作经验,融合了许多实用的功能。它通过一键分区、一键装系统、自动装驱动、一键设定分辨率,一键填IP,一键Ghost备份(恢复)等一系列...

没有备份的手机数据怎么恢复

手机没有备份恢复数据方法如下1、使用数据线将手机与电脑连接好,在“我的电脑”中可以看到手机的盘符。  2、将手机开启USB调试模式。在手机设置中找到开发者选项,然后点击“开启USB调试模式”。  3、...

电脑怎么激活windows11专业版

win11专业版激活方法有多种,以下提供两种常用的激活方式:方法一:使用激活密钥激活。在win11桌面上右键点击“此电脑”,选择“属性”选项。进入属性页面后,点击“更改产品密钥或升级windows”。...

华为手机助手下载官网(华为手机助手app下载专区)

华为手机助手策略调整,已不支持从应用市场下载手机助手,目前华为手机助手是需要在电脑上下载或更新手机助手到最新版本,https://consumer.huawei.com/cn/support/his...

光纤线断了怎么接(宽带光纤线断了怎么接)

宽带光纤线断了可以重接,具体操作方法如下:1、光纤连接的时候要根据束管内,同色相连,同芯相连,按顺序进行连接,由大到小。一般有三种连接方法,分别是熔接、活动连接和机械连接。2、连接的时候要开剥光缆,抛...

深度操作系统安装教程(深度操作系统安装教程图解)
  • 深度操作系统安装教程(深度操作系统安装教程图解)
  • 深度操作系统安装教程(深度操作系统安装教程图解)
  • 深度操作系统安装教程(深度操作系统安装教程图解)
  • 深度操作系统安装教程(深度操作系统安装教程图解)
win7旗舰版和专业版区别(win7旗舰版跟专业版)

1、功能区别:Win7旗舰版比专业版多了三个功能,分别是Bitlocker、BitlockerToGo和多语言界面; 2、用途区别:旗舰版的功能是所有版本中最全最强大的,占用的系统资源,...

万能连接钥匙(万能wifi连接钥匙下载)

1、首先打开wifi万能钥匙软件,若手机没有开启WLAN,就根据软件提示打开WLAN开关;2、打开WLAN开关后,会显示附近的WiFi,如果知道密码,可点击相应WiFi后点击‘输入密码’连接;3、若不...

雨林木风音乐叫什么(雨林木风是啥)

雨林木风的创始人是陈年鑫先生。陈年鑫先生于1999年创立了雨林木风公司,其初衷是为满足中国市场对高品质、高性能电脑的需求。在陈年鑫先生的领导下,雨林木风以技术创新、产品质量和客户服务为核心价值,不断推...

aics6序列号永久序列号(aics6破解序列号)

关于AICS6这个版本,虽然是比较久远的版本,但是在功能上也是十分全面和强大的,作为一名平面设计师的话,AICS6的现有的功能已经能够应付几乎所有的设计工作了……到底AICC2019的功能是不是...

win7正在启动windows 卡住(win7正在启动windows卡住了 进入安全模式)
  • win7正在启动windows 卡住(win7正在启动windows卡住了 进入安全模式)
  • win7正在启动windows 卡住(win7正在启动windows卡住了 进入安全模式)
  • win7正在启动windows 卡住(win7正在启动windows卡住了 进入安全模式)
  • win7正在启动windows 卡住(win7正在启动windows卡住了 进入安全模式)
手机可以装电脑系统吗(手机可以装电脑系统吗怎么装)

答题公式1:手机可以通过数据线或无线连接的方式给电脑装系统。手机安装系统需要一定的技巧和软件支持,一般需要通过数据线或无线连接的方式与电脑连接,并下载相应的软件和系统文件进行安装。对于大部分手机用户来...