电脑疯子技术论坛|电脑极客社区

微信扫一扫 分享朋友圈

已有 2062 人浏览分享

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

[复制链接]
2062 0

这篇文章主要介绍了SqlServer2016模糊匹配的三种方式及效率问题,结合实例形式简单对比分
析了SQL Server2016使用like语句、PATINDEX及CHATINDEX三种方式进行模糊匹配
的相关使用方法及执行效率,需要的朋友可以参考下


本文实例讲述了SqlServer2016模糊匹配的三种方式及效率问题。分享给大家供大家参考,具体如下:

数据库是Sqlserver 2016版

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

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

  1. select cName from tAccountAuditing where
  2. cName
  3. like '%测试moa000154%'
  4. OR
  5. cName
  6. like '%测试集团上海事业部%'
  7. and activeAuditingCodeFromJdjr = 1
复制代码


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

  1. select cName from tAccountAuditing where
  2. (
  3. PATINDEX('%测试moa000154%',cName) > 0
  4. OR
  5. PATINDEX('%测试集团上海事业部%',cName) > 0
  6. ) and activeAuditingCodeFromJdjr = 1
复制代码


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



  1. select cName from tAccountAuditing where
  2. (
  3. CHARINDEX('测试moa000154',cName) > 0
  4. OR
  5. CHARINDEX('测试集团上海事业部',cName) > 0
  6. ) and activeAuditingCodeFromJdjr = 1
复制代码


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

希望本文所述对大家SQL Server数据库程序设计有所帮助。




您需要登录后才可以回帖 登录 | 注册

本版积分规则

1

关注

0

粉丝

9021

主题
精彩推荐
热门资讯
网友晒图
图文推荐

Powered by Pcgho! X3.4

© 2008-2022 Pcgho Inc.