欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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: ) 

缺点是:在计算列上能看到可能不想被看到的数据

SQL SERVER 计算列索引 的一个应用

--创建函数

函数必须为确定性函数

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'

SQL SERVER 计算列索引 的一个应用

 

相关标签: 数据库