这篇文章主要介绍了SqlServer2016模糊匹配的三种方式及效率问题,结合实例形式简单对比分
析了SQL Server2016使用like语句、PATINDEX及CHATINDEX三种方式进行模糊匹配
的相关使用方法及执行效率,需要的朋友可以参考下
本文实例讲述了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数据库程序设计有所帮助。
|