Mybatis中模糊查询
来源:互联网 发布:linux恢复删除的文件夹 编辑:程序博客网 时间:2024/05/18 01:53
今天下午做的一个功能,要用到模糊查询,字段是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') || '%'
正确。
- MyBatis中模糊查询
- Mybatis中模糊查询
- Mybatis中模糊查询
- mybatis中模糊查询
- Mybatis中like模糊查询
- Mybatis中模糊查询的各种写法
- Mybatis中模糊查询的各种写法
- Mybatis中使用like模糊查询
- Mybatis中模糊查询的各种写法
- Mybatis中模糊查询的各种写法
- Mybatis中模糊查询的各种写法
- Mybatis中模糊查询的各种写法
- Mybatis中模糊查询的各种写法
- Mybatis中模糊查询的各种写法
- Mybatis中模糊查询的写法总结
- Mybatis中模糊查询的各种写法
- mybatis 中mysql的模糊查询
- Mybatis中mapper.xml中的模糊查询
- RocketMQ的坑(一)--搭好环境跑起来
- 39.线程同步
- 注解(Annotation)自定义注解入门
- Android设计模式——单例的七种写法
- wangEditor3使用AJAX异步上传图片
- Mybatis中模糊查询
- 蓝牙核心技术概述(四):蓝牙协议规范(HCI、L2CAP、SDP、RFOCMM)
- SQL系列(函数)
- android telnet 连接
- Oracle函数substr与instr
- androidstudio app icon 尺寸标准
- Intellij Idea 创建一个简单的Web项目
- Java assert
- ORBSLAM2编译运行数据集(亲测可用)