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

--此用例在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'

执行计划

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值