本文实例讲述了SqlServer2016模糊匹配的三种方式及效率问题。分享给大家供大家参考,具体如下:
数据库是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都要好~
更多关于SQL Server相关内容感兴趣的读者可查看本站专题:《SQL Server查询操作技巧大全》、《SQL Server日期与时间操作技巧总结》、《SQL Server存储过程技巧大全》、《SQL Server索引操作技巧大全》及《SQL Server常用函数汇总》
希望本文所述对大家SQL Server数据库程序设计有所帮助。
继续阅读与本文标签相同的文章
-
住客扫码住酒店疑被收集信息?华住回应:不排除个别员工引导
2026-05-15栏目: 教程
-
5G网络即将来临,家里的宽带还有存在的必要吗?听听专家怎么说
2026-05-15栏目: 教程
-
禅城奇槎最快本月底将推出41亩商住地
2026-05-15栏目: 教程
-
广汽新能源Aion LX上市:售价24.96万元起,综合续航650公里
2026-05-15栏目: 教程
-
能打败复读机的,只有禁止套娃了
2026-05-15栏目: 教程
