SQL SERVER 计算列索引 的一个应用
程序员文章站
2024-01-20 18:59:28
...
--此用例在SQLSERVER 2019上测试通过
select @@VERSION
--Microsoft SQL Server 2019 (RTM) - 15.0.2000.5 (X64) Sep 24 2019 13:48:23
--Copyright (C) 2019 Microsoft Corporation Developer Edition (64-bit)
--on Windows 10 Pro 10.0 <X64> (Build 18363: )
缺点是:在计算列上能看到可能不想被看到的数据
--创建函数
函数必须为确定性函数
create function func_en(@va varbinary(200)) RETURNS varchar(4000)
with SCHEMABINDING --通过此关键词将函数定义为确定性函数
AS
BEGIN
RETURN CONVERT( VARCHAR(4000),DECRYPTBYPASSPHRASE('test',@va, 1,CONVERT( varbinary, 'fjw')));
END
--创建表
Create Table TestFunctionIndex
(
id int identity(1,1),
cvb VARBinary(200),
val as [dbo].[func_en](cvb) --增加一个持久化计算列
)
GO
--在持久化计算列上建立索引
create index idx_val on TestFunctionIndex(val);
GO
--插入10000行测试数据
insert into TestFunctionIndex(cvb) values (ENCRYPTBYPASSPHRASE('test', CONVERT(VARCHAR(200),NEWID()), 1, CONVERT( varbinary,'fjw' )))
go 10000
使用条件查询,执行计划显示使用索引
select * from TestFunctionIndex
where val='A4CE6B17-21D3-42E0-AFC5-CB557B56E522'