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

生活中只有两种选择:重新开始,成为自己生活的主角;或留在原处并成为他人的支持角色。生活中,很多时候都需要我们要耐心,耐心做人,耐心做事,更要耐心生活。

本文实例讲述了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数据库程序设计有所帮助。

本文SqlServer2016模糊匹配的三种方式及效率问题简析到此结束。没有命中注定的结局,仅有不够努力的过程。小编再次感谢大家对我们的支持!

您可能有感兴趣的文章
SQL 将一列拆分成多列的三种方法

SQLServer三种锁定模式的知识讲解

SQLServer数据库的三种恢复模式:简单恢复模式、完整恢复模式和大容量日志恢复模式

SQLSERVER数据库备份的三种策略及语句