加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SqlServer 2016模糊匹配的几种方式和效率问题

发布时间:2020-12-12 13:44:38 所属栏目:MsSql教程 来源:网络整理
导读:数据库是Sqlserver 2016版 现在业务需求是:要查询出企业名称为以下几个的,XXX,XXXX等等: 第一种方式: like '%XXX%' OR like '%XXXX%' select cName from tAccountAuditing where cNamelike '%测试moa000154%' ORcNamelike '%测试集团上海事业部%' and a

数据库是Sqlserver 2016版

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


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

select cName from tAccountAuditing where  
cName
like '%测试moa000154%' 
OR
cName
like '%测试集团上海事业部%' 
and activeAuditingCodeFromJdjr = 1

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

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

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

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

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读