【MyBatis】多关键字的模糊查询
任务驱动才能明确方向。我举一个例子。
情景分析
题目
现在我们要执行查询操作,例如我要查询商品的供应商信息。供应商的信息包括公司名称,负责人名字,联系电话,公司地址等。
我也许会输入电话号码的前几位查询,也许会输入公司名称的某个字查询,也许会输出负责人的姓氏查询……
我希望查出来的结果,是按照Id升序排序好了的。
要求
1.我要根据公司名称查询,只要公司名称包含“广东”、“深圳”的都可以被查询出来
2.我要根据负责人名字查询,只要负责人名字包含“周”、“吴”、“郑”、“王”的都可以被查询出来
3.我要根据电话号码查询,只要电话号码包含“139”,“136”,“137”的都可以被查询出来
相关代码
下面MyBatis的配置方式是Spring整合MyBatis的,详情请参阅下面这篇文章
Mapper.java
/**
* 查询供应商信息
* @param way 查询方式。1:根据供应商公司名称模糊查询 2:根据供应商负责人名字模糊查询 3:根据电话模糊查询
* @param npcs 查询的关键字
* @return List<SmbmsProvider>
*/
public List<SmbmsProvider> getProviderByNCP(@Param("way") int way, @Param("npcs") List<String> npcs);
SmbmsProvider是供应商对象。
Impl.java
package cc.mllt.impl;
import cc.mllt.mapper.ProviderMapper;
import cc.mllt.pojo.SmbmsProvider;
import org.mybatis.spring.SqlSessionTemplate;
import java.util.List;
//实现类
public class ProviderImpl implements ProviderMapper {
private SqlSessionTemplate sqlSessionTemplate;
public void setSqlSessionTemplate(SqlSessionTemplate sqlSessionTemplate){
this.sqlSessionTemplate=sqlSessionTemplate;
}
@Override
public List<SmbmsProvider> getProviderByNCP(int way, List<String> npcs) {
ProviderMapper providerMapper = sqlSessionTemplate.getMapper(ProviderMapper.class);
return providerMapper.getProviderByNCP(way,npcs);
}
}
mapper.xml
<!-- public List<SmbmsProvider> getProviderByNCP(@Param("way") int way, @Param("npc") List<String> npcs);-->
<select id="getProviderByNCP" resultType="SmbmsProvider">
select * from smbms_provider
<choose>
<when test="way==1">
where
<foreach item="npc" index="index" collection="npcs" open="" separator=" or " close="">
<if test="npc!=''">
proName like concat('%',#{npc},'%')
</if>
</foreach>
</when>
<when test="way==2">
where
<foreach item="npc" index="index" collection="npcs" open="" separator=" or " close="">
<if test="npc!=''">
proContact like concat('%',#{npc},'%')
</if>
</foreach>
</when>
<when test="way==3">
where
<foreach item="npc" index="index" collection="npcs" open="" separator=" or " close="">
<if test="npc!=''">
proPhone like concat('%',#{npc},'%')
</if>
</foreach>
</when>
<otherwise>
where
<foreach item="npc" index="index" collection="npcs" open="" separator=" or " close="">
<if test="npc!=''">
proName like concat('%',#{npc},'%')
</if>
</foreach>
</otherwise>
</choose>
order by `id`
</select>
经过测试,当List类型参数包含Null时,不会对结果造成影响,因此我上面没有进行null的判断,如果你有需求,可以加上
经过测试,当List类型参数包含""(也就是空)的时候,会导致将所有数据都查询出来了,因此要判断内容不为空
了解
MyBatis foreach标签相关信息请查阅:MyBatis foreach标签 (biancheng.net)
test.java
ClassPathXmlApplicationContext context= new ClassPathXmlApplicationContext("applicationContext.xml");
ProviderMapper providerMapper = context.getBean("providerMapperBean",ProviderMapper.class);
@Test
public void getProviderByNCPTest(){
List<String> list1 = new ArrayList<>();
//下面两个是我们要查询的
list1.add("北京");
list1.add("深圳");
//下面这些是用来测试的
list1.add(null);
list1.add("");
//下面这句话是分页插件的使用,未使用分页插件则忽略这句话
Page<Object> page = PageHelper.startPage(1,3);
//执行查询操作
List<SmbmsProvider> result1 = providerMapper.getProviderByNCP(1,list1);
//方式1查询结果合集,通过分页插件整理了的
PageInfo<SmbmsProvider> pageInfo1 = new PageInfo<>(result1,3);//三页
//输出相关分页的信息
System.out.println(page);
System.out.println(pageInfo1);
//从分页信息中取出查询到的数据
result1=pageInfo1.getList();
//格式化输出
System.out.println("--------------------根据公司名称查询--------------------");
for(SmbmsProvider smbmsProvider:result1){
System.out.println(smbmsProvider.getId()+"\t"+smbmsProvider.getProCode()+"\t"+smbmsProvider.getProName()+"\t"+ smbmsProvider.getProContact()+"\t"+smbmsProvider.getProPhone());
}
}
【输出结果如下】
思路分析
1.最开始,参数没有使用List,引起的问题
/**
* 查询供应商信息
* @param way 查询方式。1:根据供应商公司名称模糊查询 2:根据供应商负责人名字模糊查询 3:根据电话模糊查询
* @param npc 查询的关键字
* @return List<SmbmsProvider>
*/
public List<SmbmsProvider> getProviderByNCP(@Param("way") int way, @Param("npc") String npc);
这种方式有一个问题,我查询“北京”,“深圳”需要分为两次查询,后面手动将查询结果合并在一起,然后又要去考虑id升序排序问题……
正如你所见,很麻烦。尤其是排序问题。因为得到的结果是List,排序要根据List里面的SmbmsProvider对象里面的id排序。
如果能一起将多个关键字一起查询,将得到的结果,一个Order By 就解决了,所以,我们要去考虑使用的参数应该是个List,然后里面包含我们想要查询的多个关键字。
那么传入一个List,又怎么在Mapper.xml中取出想要的东西呢,就发现了后面的 MyBatis foreach
2.Mybatis的foreach
了解
MyBatis foreach标签相关信息请查阅:MyBatis foreach标签 (biancheng.net)
3. npc != ''
注意标题上的是两个单引号,而不是一个双引号
为什么我特意用一个 if做判断?
这里应对的是List中存在空
1:如果整个列表都空的(也就是一个空列表)
List<String> list1 = new ArrayList<>();
list1.add(null);
list1.add("");
我们没有在When中进行判断,列表是否为空,所以它会继续执行下去

到达foreach的时候,开始遍历,如果为空,则后续无语句,若不为空,则继续添加if块中的语句
测试当空List传入时,结果如下

4.其他
分页插件在这篇文章并没有得到充分的应用。
【MyBatis】多关键字的模糊查询的更多相关文章
- MyBatis Plus之like模糊查询中包含有特殊字符(_、\、%)
传统的解决思路:自定义一个拦截器,当有模糊查询时,模糊查询的关键字中包含有上述特殊字符时,在该特殊字符前添加\进行转义处理. 新的解决思路:将like 替换为 MySQL内置函数locate函数 参考 ...
- 【Mybatis】【3】mybatis Example Criteria like 模糊查询
正文: 在Java中使用Mybatis自动生成的方法,like需要自己写通配符 public List<TableA> query(String name) { Example examp ...
- Mybatis使用MySQL进行模糊查询时输入中文检索不到结果
Mybatis使用MySQL进行模糊查询时输入中文检索时,需要在jdbcURL后增加参数 ?useUnicode=true&characterEncoding=UTF-8
- mybatis框架入门程序:演示通过mybatis实现数据库的模糊查询操作
1. mybatis的基本准备操作见我的上一篇博文:https://www.cnblogs.com/wyhluckdog/p/10149480.html 2. 根据用户名查询用户信息: (1)映射文件 ...
- mybatis Example Criteria like 模糊查询
用Mybatis代码生成工具会产生很多个XXXExample类,这些类的作用是什么? 查阅了很多资料,在这里总结归纳一下 简介XXXExample类用于构造复杂的筛选条件 它包含一个名为Criteri ...
- MyBatis动态SQL与模糊查询
sqlxml <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC & ...
- mybatis中根据日期模糊查询
首先设置起始日期startDate和结束日期endDate,数据库中日期字段为achive_time,表名为dos_dossier<select id="getDossiers&quo ...
- mybatis 动态Sql的模糊查询
where teacher.tname like concat(concat(#{tName}),'%') 2:distinct的使用 下面先来看看例子: table id name 1 ...
- Mybatis中的like模糊查询四种方式
1. 参数中直接加入%% param.setUsername("%CD%"); param.setPassword("%11%"); <select i ...
随机推荐
- 组合(n选k问题)
#include "iostream.h" #include "string.h" int a[100]; void dfs(int n,int k) { if ...
- kafka中的broker 是干什么的?
broker 是消息的代理,Producers往Brokers里面的指定Topic中写消息,Consumers从Brokers里面拉取指定Topic的消息,然后进行业务处理,broker在中间起到一 ...
- Spring框架中有哪些不同类型的事件?
Spring 提供了以下5种标准的事件: (1)上下文更新事件(ContextRefreshedEvent):在调用ConfigurableApplicationContext 接口中的refre ...
- Constant Pool和String Constant Pool详解
Constant Pool常量池的概念: 在讲到String的一些特殊情况时,总会提到String Pool或者Constant Pool,但是我想很多人都不太明白Constant Pool到底是个怎 ...
- 学习Solr(三)
本文以solr5为例说明在linux系统上单机安装过程. 一. solr的安装 1. solr能够安装在不同的操作系统上,安装solr前需要安装何时的JRE.当前版本5.5最低需要JRE1. ...
- Python turtle 模块可以编写游戏,是真的吗?
1. 前言 turtle (小海龟) 是 Python 内置的一个绘图模块,其实它不仅可以用来绘图,还可以制作简单的小游戏,甚至可以当成简易的 GUI 模块,编写简单的 GUI 程序. 本文使用 tu ...
- 企业流程再造(BPR)--系统重构
企业流程再造(BPR) 企业流程:指生产或服务过程中一连串活动的工作流程 企业流程再造:对企业流程所进行的根本性的在思考和彻底的再设计,以使企业的速度,质量,服务和成本等关键业绩指标获得根本性的改善
- 10.Flink实时项目之订单维度表关联
1. 维度查询 在上一篇中,我们已经把订单和订单明细表join完,本文将关联订单的其他维度数据,维度关联实际上就是在流中查询存储在 hbase 中的数据表.但是即使通过主键的方式查询,hbase 速度 ...
- 当心,你搞的Scrum可能是小瀑布
摘要:有的团队刚接触Scrum,一个问题令他们很困扰:迭代初期开发人员的工作较多,测试人员闲着:迭代末期开发人员闲着,测试人员的工作比较多,怎么解决资源等待的问题呢? 本文分享自华为云社区<当心 ...
- Altium Designer 原理图的绘制前导
元件库.封装库设计 部分元器件厂商或者经销商不提供元件库和封装库,只给了元器件尺寸图,所以需要自行设计元件库文件或是封装库文件 元件库设计: 新建 .SchLib 文件:File -> N ...
