mybatis mapper.xml 区间查询条件详解
更新时间:2021年9月30日 16:00 点击:1805
mybatis mapper.xml 区间查询条件
对 null 和 ” 分开进行判断
<select id="selectByExample" resultMap="BaseResultMap" parameterType="com.test.entity.TestQuery"> SELECT * FROM test s WHERE 1=1 <!-- 创建时间 --> <if test="createTime!=null and createTime!=''"> AND s.create_time = #{createTime,jdbcType=TIMESTAMP} </if> <!-- 开始创建时间,结束创建时间都不为空 --> <if test="beginCreateTime!=null and beginCreateTime!='' and endCreateTime!=null and endCreateTime!=''"> AND s.create_time >= #{beginCreateTime,jdbcType=TIMESTAMP} AND s.create_time <= #{endCreateTime,jdbcType=TIMESTAMP} </if> <!-- 开始不为空,结束为空 null --> <if test="beginCreateTime!=null and beginCreateTime!='' and endCreateTime==null"> AND s.create_time >= #{beginCreateTime,jdbcType=TIMESTAMP} </if> <!-- 开始不为空,结束为空 '' --> <if test="beginCreateTime!=null and beginCreateTime!='' and endCreateTime==''"> AND s.create_time >= #{beginCreateTime,jdbcType=TIMESTAMP} </if> <!-- 开始为空 null,结束不为空 --> <if test="beginCreateTime==null and endCreateTime!=null and endCreateTime!=''"> AND s.create_time <= #{endCreateTime,jdbcType=TIMESTAMP} </if> <!-- 开始为空 '',结束不为空 --> <if test="beginCreateTime=='' and endCreateTime!=null and endCreateTime!=''"> AND s.create_time <= #{endCreateTime,jdbcType=TIMESTAMP} </if> </select>
tk mybatis通用mapper,复杂and or条件查询
需求:where查询,需要支持(a or b or c) and d
也就是a、b、c三个条件是或的关系,然后再与d相与。
尝试后,可以通过以下方式处理:
方式1:Weekend语法
Weekend<User> weekend = new Weekend<>(User.class); //关键字查询部分 String keyword = pageReq.getKeyword(); WeekendCriteria<User, Object> keywordCriteria = weekend.weekendCriteria(); if (StringUtils.isNotEmpty(keyword)) { keywordCriteria.orLike(User::getUserName, keyword).orLike(User::getPoliceNo, keyword).orLike(User::getRealName, keyword); //此处不需要再用下面这一句了,不然上面这个条件组合会重复一次 //weekend.and(keywordCriteria) } //部门查询部分 Example example = new Example(User.class); Example.Criteria criteria = example.createCriteria(); criteria.andEqualTo("departmentId", departmentId); weekend.and(criteria); PageHelper.startPage(pageReq.getPageIndex(), pageReq.getPageSize()); List<User> users = userMapper.selectByExample(weekend);
ps:上面,其中Weekend是高版本的通用mapper版本才有,而且需要java8语法支持。
方式2:通用example语法
Example e = new Example(User.class); Example.Criteria c = e.createCriteria(); //关键字查询部分 String keyword = pageReq.getKeyword(); if (StringUtils.isNotEmpty(keyword)) { c.orEqualTo("userName", keyword).orEqualTo("policeNo",keyword).orEqualTo("realName",keyword); } //部门查询部门 Example.Criteria criteria = e.createCriteria(); criteria.andEqualTo("departmentId", departmentId); e.and(criteria); PageHelper.startPage(pageReq.getPageIndex(), pageReq.getPageSize()); List<User> users = userMapper.selectByExample(e);
执行的sql为:
WHERE ( user_name = ? OR police_no = ? OR real_name = ? ) AND (department_id = ?)
总结下来,就是,
每个条件组合(a/b/c) (d)各自创建自己的cirteria,再用and或者or方法去连接
以上为个人经验,希望能给大家一个参考,也希望大家多多支持猪先飞。
下一篇: 使用Java实现5种负载均衡算法实例
相关文章
- 这篇文章主要介绍了Mybatis Plus select 实现只查询部分字段的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-09-01
- 这篇文章主要介绍了解决Mybatis 大数据量的批量insert问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-01-09
- 这篇文章主要介绍了mybatis的Configuration详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-11-04
mybatis 返回Integer,Double,String等类型的数据操作
这篇文章主要介绍了mybatis 返回Integer,Double,String等类型的数据操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-11-25- 数据库中的数据删除会分为两种:物理删除 和 逻辑删除,接下来通过本文给大家介绍MyBatis-Plus的物理删除和逻辑删除使用场景分析,感兴趣的朋友一起看看吧...2021-09-25
Springboot如何使用mybatis实现拦截SQL分页
这篇文章主要介绍了Springboot使用mybatis实现拦截SQL分页,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-06-19- 这篇文章主要介绍了Mybatis执行update失败的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-09-01
- 这篇文章主要介绍了Mybatis plus中使用in查询出错的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-08-06
解决Mybatis中mapper.xml文件update,delete及insert返回值问题
这篇文章主要介绍了解决Mybatis中mapper.xml文件update,delete及insert返回值问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-11-23- Mybatis-Plus是一个Mybatis的增强工具,它在Mybatis的基础上做了增强,却不做改变,Mybatis-Plus是为简化开发、提高开发效率而生,但它也提供了一些很有意思的插件,比如SQL性能监控、乐观锁、执行分析等,下面一起看看mybatis-plus雪花算法自动生成机器id原理解析...2021-06-04
- 这篇文章主要介绍了Mybatis用注解写in查询的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-07-13
- 这篇文章主要介绍了Mybatis和Mybatis-Plus时间范围查询方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-08-06
- 这篇文章主要介绍了mybatis Map查询结果下划线转驼峰的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-09-24
Mybatis之Select Count(*)的获取返回int的值操作
这篇文章主要介绍了Mybatis之Select Count(*)的获取返回int的值操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-11-23Springboot mybatis plus druid多数据源解决方案 dynamic-datasource的使用详解
这篇文章主要介绍了Springboot mybatis plus druid多数据源解决方案 dynamic-datasource的使用,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-11-18Mybatis Plus 字段为空值时执行更新方法未更新解决方案
这篇文章主要介绍了Mybatis Plus 字段为空值时执行更新方法未更新解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-09-03关于IDEA 2020使用 mybatis-log-plugin插件的问题
这篇文章主要介绍了关于IDEA 2020使用 mybatis-log-plugin插件的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-11-10- 这篇文章主要介绍了Mybatis返回结果封装map过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-09-19
springboot配置多数据源后mybatis拦截器失效的解决
这篇文章主要介绍了springboot配置多数据源后mybatis拦截器失效的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-09-23- 这篇文章主要介绍了Mybatis批量修改时出现报错问题解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-11-10