SQL Server 2014,表变量上的非聚集索引
从Paul White的推特上看到,在SQL Server 2014里,对于表变量(Table Variables),它是支持非唯一聚集索引(Non-Unique Clustered Indexes)和非聚集索引(Non-Clustered Indexes)的。看到这个,我决定在自己的虚拟机里尝试下,因为这将是个卓越的功能。表变量很棒,因为用它可以避免过多的重编译(excessive recompilations)。当你创建它们时,它们是没有统计信息,你不会改变数据库架构。它们只是变量,但在TempDb里还是常驻的。
表变量的一个缺点是,你不能在上面创建非聚集索引,这个在处理大量数据集时是不好的。但SQL Server 2014 CTP1已经修正了这个缺点。来看下面的代码(点击工具栏的显示包含实际的执行计划):
DECLARE @tempTable TABLE ( ID INT IDENTITY(1, 1) PRIMARY KEY, FirstName CHAR(100) INDEX idx_FirstName, LastName CHAR(100) ) INSERT INTO @TempTable (FirstName, LastName) SELECT TOP 100000 name, name FROM master.dbo.syscolumns SELECT FirstName FROM @TempTable WHERE FirstName = 'cid' GO
我们来看下SELECT语句的执行计划,SQL Server执行了非聚集索引扫描运算符(Non-Clustered Index Seek operator)。也就是说,我们可以在表变量上定义额外的非聚集索引。每个创建的非聚集索引是没有统计信息。这个功能很酷哦,在常规数据库表的简单语 法(easy syntax)也支持。我们来看下面的表定义:
CREATE TABLE foo ( Col1 INT PRIMARY KEY CLUSTERED, Col2 INT INDEX idx_Col2, Col3 INT INDEX idx_Col3 ) GO
这个在SQL Server 2008R2上会提示如下错误:
在SQL Server 2014上却能成功执行!
更进一步,我们还可以用新语法创建复合索引(composite indexes):
-- Inline creation of Indexes CREATE TABLE foo2 ( Col1 INT PRIMARY KEY CLUSTERED, Col2 INT INDEX idx_Col2 (Col2, Col3), Col3 INT ) GO
之前的版本(我这里是SQL Server 2008R2)只能如下出错提示:
真是酷炫叼炸天了,大家赶紧都去体验下!
注:此文章为WoodyTu学习MS SQL技术,收集整理相关文档撰写,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出此文连接!
若您觉得这篇文章还不错请点击下右下角的推荐,有了您的支持才能激发作者更大的写作热情,非常感谢!