T-SQL---多值模糊查询的处理

多值模糊查询的处理

所谓多值模糊查询,就是应用程序中传递过来多个参数,对这些参数做拆分,拆分之后,对拆分结果的key值分别做模糊查询处理

对于精确匹配时,不管是单个Key值还是多个Key值,都很容易处理,备选方案也很多

对于模糊查询,单个key值也很容易,也就是 ……where name like ‘%parameter%‘(不要告诉我全模糊效率低之类的,我这里不是做性能对比的)

但是对于多个Key值的模糊处理,就不是太直接了,比如name字段,输入‘三,四,五‘,要求分别按照三,四,五三个字符做模糊匹配

多值模糊查询可以参考如下的方式处理,欢迎提供更好的办法,谢谢了

CREATE TABLE [dbo].[Student](    [S#] [varchar](50) NULL,    [Sname] [varchar](50) NULL,    [Ssex] [varchar](2) NULL)INSERT INTO Student VALUES (1,‘张三‘,1)INSERT INTO Student VALUES (2,‘李四‘,1)INSERT INTO Student VALUES (3,‘王五‘,1)INSERT INTO Student VALUES (4,‘赵六‘,1)INSERT INTO Student VALUES (5,‘孙七‘,1)--精确匹配的话,不管是单值还是多值,都很好处理select * from Student where Sname in (‘张三‘,‘李四‘)--单值模糊的好处理select * from Student where Sname Like ‘%五%‘--多值模糊匹配,就没有这么直接了--所谓的多值模糊匹配,就是外面传递进来多个值,这些值差分开之后,每个值都做模糊查询--SQL既要写满足功能性需求,又要简明的清晰,一开始还想写函数什么玩意的,--后来想了想,可以这么处理;with CTENameas(    --这是一个字符串拆分函数
    select id,concat(‘%‘,s,‘%‘) as name from dbo.f_splitStrToTable(‘四,五,六‘,‘,‘)
)select * from Studentwhere exists(    select 1 from CTEName where Sname like name
)--查询结果S# Sname Ssex2 李四 13 王五 14 赵六 1(3 row(s) affected)

时间: 2025-01-05 11:41:47

T-SQL---多值模糊查询的处理的相关文章

在JDBC中实现SQL语句的模糊查询

在JDBC中实现SQL语句的模糊查询 在大多数情况下我们可以在JDBC中写入sql语句通过占位符的方式来直接查询,但是如果要进行模糊查询,需要转义字符才能够正常查询. sql语句: select * from table where tableid like %id%; JDBC中的sql语句: String sql = "select * from table where tableid like \"%\"?\"%\"";//?为占位符 原文

SQL中常用模糊查询的四种匹配模式

执行数据库查询时,有完整查询和模糊查询之分.一般模糊语句如下:SELECT 字段 FROM 表 WHERE 某字段 Like 条件 其中关于条件,SQL提供了四种匹配模式:1.%:表示任意0个或多个字符.可匹配任意类型和长度的字符,有些情况下若是中文,请运用两个百分号(%%)表示.比如 SELECT * FROM [user] WHERE u_name LIKE '%三%'将会把u_name为"张三","张猫三"."三脚猫","唐三藏&

SQL中常用模糊查询的四种匹配模式&&正则表达式

执行数据库查询时,有完整查询和模糊查询之分.一般模糊语句如下:SELECT 字段 FROM 表 WHERE 某字段 Like 条件 其中关于条件,SQL提供了四种匹配模式:1.%:表示任意0个或多个字符.可匹配任意类型和长度的字符,有些情况下若是中文,请运用两个百分号(%%)表示.比如 SELECT * FROM [user] WHERE u_name LIKE '%三%'将会把u_name为“张三”,“张猫三”.“三脚猫”,“唐三藏”等等有“三”的记录全找出来.另外,如果须要找出u_name中

Sql Like 通配符 模糊查询技巧及特殊字符

1. SQL like对时间查询的处理方法 SQL数据表中有savetime(smalldatetime类型)字段,表中有两条记录,savetime值为:2005-3-8 12:12:00和2005-6-6 14:02:02 我用下面语句什么也搜不出来 select * from soft where soft.savetime like'%2005-3-8%' SQL帮助中说: "当搜索 datetime 值时,推荐使用 LIKE,因为 datetime 项可能包含各种日期部分.例如,如果将值

SQL like使用 模糊查询

模糊查询: 参考资料:http://www.w3school.com.cn/sql/sql_wildcards.asp 在搜索数据库中的数据时,您能够使用 SQL 通配符. SQL 通配符  Like 在搜索数据库中的数据时,SQL 通配符能够替代一个或多个字符. SQL 通配符必须与 LIKE 运算符一起使用. 在 SQL 中,可使用下面通配符: 通配符 描写叙述 % 替代一个或多个字符 _ 仅替代一个字符 [charlist] 字符列中的不论什么单一字符 [^charlist] 或者 [!c

SSM-MyBatis-05:Mybatis中别名,sql片段和模糊查询加getMapper

------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 简单概述一下本讲 别名,sql片段简单写一下,模糊查询多写一点 一.别名 <typeAliases> <!--第一种--> <!--<typeAlias type="cn.dawn.demo01.entity.Book" alias="book"></typeAlias>--> <!--第二种--> <

geoserver配置SQL图层 cql_filter模糊查询

1.新建图层,选择对应的 数据源 2创建SQL源图层 3.写好SQL,刷新,需要注意设置主键为标识符,设置空间数据为Geometory 4326 4.数据过滤访问地址,支持cql_filter 模糊查询 http://hhzc.hubeiwater.gov.cn/geoserver//ows?service=WFS&version=1.0.0&request=GetFeature&maxFeatures=500000&outputFormat=application%2Fj

SQL 怎么实现模糊查询?

执行数据库查询时,有完整查询和模糊查询之分. 一般模糊语句格式如下: SELECT 字段 FROM 表 WHERE 某字段 LIKE 条件; 其中,关于条件,SQL提供了四种匹配模式: 一.%:表示零个或多个字符. 可以匹配任意类型和任意长度的字符,有些情况下若是中文,请使用两个百分号(%%)表示. select * from flow_user where username like '%王%'; 将会把flow_user这张表里面,列名username中含有"王"的记录全部查询出来

SQL SERVER 的模糊查询 LIKE

今天写个动态脚本,需要把数据库里面包含“USER_"的表删除掉,突然想不起来如何搜索通配字符了,赶紧查查MSDN,整理了下模糊查询的知识点,留着以后查阅用. LIKE模糊查询的通配符 通配符 说明 示例 % 包含零个或多个字符的任意字符串. WHERE title LIKE '%computer%' 将查找在书名中任意位置包含单词 "computer" 的所有书名. _(下划线) 任何单个字符. WHERE au_fname LIKE '_ean' 将查找以 ean结尾的所有