SQL中的模糊查询语句

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL中的模糊查询语句相关的知识,希望对你有一定的参考价值。

参考技术A 分类: 电脑/网络 >> 程序设计 >> 其他编程语言
问题描述:

假如我有一个表a,表a中有一个字段b,字段b中一条记录为"芝宝打火机经济版猎人银白色"

我在SQL中要用模糊查找,找到b字段中的这条记录

select * from a where b like'%经济猎人%'

这样查是查不到这条记录的,只有这样才能查到:

select * from a where b like'%经济版猎人%'

问问,怎样写才可以,我在输入"经济猎人"的情况下查到这条记录?

解析:

拆词,把需要模糊查询的字符串,SPLIT拆开 2个字为一组

然后UBOUND 这个字符串个数

for i=1 to ubound

str = " Select * from a where b like % 数组(0) % "

next

选择出来以后 在做筛选

mybatis模糊查询sql

今天下午做的一个功能,要用到模糊查询,字段是description,刚开始我的写法用的是sql中的模糊查询语句,

但是这个有问题,只有将字段的全部值传入其中,才能查询,所以不是迷糊查询。

后来经过搜索,发现要加上一个concat字段,要先将字符串拼接后,才能实现模糊查询。

改成这个样子后,模糊查询功能实现。

 

在我搜索到的博客中海油别的几种写法,但是试验了两个,有一个成功,另外一个没能实现模糊查询,但是目前还不知道错误在哪里。如果有人知道,请赐教。

他的博客地址是:http://blog.sina.com.cn/s/blog_667bef380101f2da.html

我使用的就是他所说的第一种方法:

1. sql中字符串拼接

   SELECT * FROM tableName WHERE name LIKE CONCAT(CONCAT(\'%\', #{text}), \'%\');

我就是按照此方法实现了功能。

 其实还有种方法:像这样写也行:

他的第二种方法:

2. 使用 ${...} 代替 #{...}

   SELECT * FROM tableName WHERE name LIKE \'%${text}%\';

这个我试过之后,发现并没有实现模糊查询的功能,而且目前也不知道哪里出错了,如果有人知道请指教。

 

他的第三种方法:

 

3. 程序中拼接

 

   Java

 

   // String searchText = "%" + text + "%";

 

   String searchText = new StringBuilder("%").append(text).append("%").toString();

 

   parameterMap.put("text", searchText);

 

 

 

   SqlMap.xml

 

   SELECT * FROM tableName WHERE name LIKE #{text};

这个方法我没有试过,但是还是记录下来,以后试试

 

他还有第四种方法

 

4. 大小写匹配查询

 

   SELECT *  FROM TABLENAME  WHERE UPPER(SUBSYSTEM) LIKE \'%\' || UPPER(\'jz\') || \'%\'

 

   或者 

 

   SELECT *   FROM TABLENAME  WHERE LOWER(SUBSYSTEM) LIKE \'%\' || LOWER(\'jz\') || \'%\'

正确。

http://www.cnblogs.com/dushan/p/4766954.html

以上是关于SQL中的模糊查询语句的主要内容,如果未能解决你的问题,请参考以下文章

sql语句模糊查询的问题?

mssql中一个简单的模糊查询语句怎么写请教大侠们

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

关于sql语句模糊查询

java模糊查询sql语句问题

C# Access 模糊查询SQL语句