全国统一服务热线:400-633-9193

SqlServer2016模糊匹配的三种方式及效率问题简析

    网络     2018-07-23    2676

本文实例讲述了SqlServer2016模糊匹配的三种方式及效率问题。分享给大家供大家参考,具体如下:

数据库是Sqlserver 2016版

现在业务需求是:要查询出企业名称为以下几个的,XXX,XXXX等等:

第一种方式:like '%XXX%' OR like '%XXXX%'

1
2
3
4
5
6
7
select cName from tAccountAuditing where
cName
like '%测试moa000154%'
OR
cName
like '%测试集团上海事业部%'
and activeAuditingCodeFromJdjr = 1

第二种方式:PATINDEX('%XXX%',cName) > 0

1
2
3
4
5
6
select cName from tAccountAuditing where
(
PATINDEX('%测试moa000154%',cName) > 0
OR
PATINDEX('%测试集团上海事业部%',cName) > 0
) and activeAuditingCodeFromJdjr = 1

第三种方式:CHATINDEX('XXX',cName) > 0   这里不要百分号的啊

1
2
3
4
5
6
select cName from tAccountAuditing where
(
CHARINDEX('测试moa000154',cName) > 0
OR
CHARINDEX('测试集团上海事业部',cName) > 0
) and activeAuditingCodeFromJdjr = 1

效率上的话,后两种比like都要好~


  分享到:  
0.2045s