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

所属分类: 数据库 / MsSql 阅读数: 1100
收藏 0 赞 0 分享

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

更多精彩内容其他人还在看

sql Set IDENTITY_INSERT的用法

SET IDENTITY_INSERT 允许将显式值插入表的标识列中。
收藏 0 赞 0 分享

sql 修改表的所有者

有时候因为一些权限问题,需要修改表的所有者,下面的方法不错
收藏 0 赞 0 分享

过程需要参数 '@statement' 为 'ntext/nchar/nvarchar' 类型

过程需要参数
收藏 0 赞 0 分享

mssql 建立索引第1/2页

假设你想找到本书中的某一个句子。你可以一页一页地逐页搜索,但这会花很多时间。而通过使用本书的索引,你可以很快地找到你要搜索的主题。
收藏 0 赞 0 分享

SQL Server 索引结构及其使用(一)--深入浅出理解索引结构第1/4页

深入浅出理解索引结构
收藏 0 赞 0 分享

SQL Server 索引结构及其使用(二) 改善SQL语句第1/3页

很多人不知道SQL语句在SQL SERVER中是如何执行的,他们担心自己所写的SQL语句会被SQL SERVER误解。
收藏 0 赞 0 分享

获取MSSQL数据字典的SQL语句

获取MSSQL数据字典的实现方法。
收藏 0 赞 0 分享

Microsoft Search 服务无法启动 解决办法.

尝试用正常系统的注册表项添加到非正常系统中去。(因为对比的两个系统版本、结构相同,所此次就直接通过导入导出注册表项进行批量修改)。
收藏 0 赞 0 分享

找出所有非xml索引并重新整理的sql

找出所有非xml索引
收藏 0 赞 0 分享

SQL Server提示"选定的用户拥有对象,所以无法除去该用户”

今天在帮朋友弄一台服务器的时候当我需要删除一个数据库里的用户时,提示如下错误信息: "选定的用户拥有对象,所以无法除去该用户" 如何解决呢?
收藏 0 赞 0 分享
查看更多