本文实例讲述了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都要好~
希望本文所述对大家SQL Server数据库程序设计有所帮助。
原文链接:https://blog.csdn.net/xb12369/article/details/72820166