mybatis的mapper特殊字符转移及动态SQL条件查询小结
目录
- 前言
- 条件查询
- 快速入门
- if标签
- where标签
- choose when otherwise标签
- foreach标签
- 场景案例
前言 我们知道在项目开发中之前使用数据库查询,都是基于
jdbc
,进行连接查询,然后是高级一点jdbcTemplate
进行查询,但是我们发现还是不是很方便,有大量重复sql语句,与代码偶合,效率低下,于是就衍生出来ORM
框架,如Mybatis,Hibernate,
还有SpringBoot的,Spring Data JPA
条件查询 我们知道在
mybatis mapper
文件中条件查询符,如>=,<,
之类是不能直接写的会报错的需要转移一下 如下图表文章图片
详细内容参考
常见的条件查询操作有
文章图片
我们通过mybatis 提供的特有标签进行条件判断,达到动态拼接
sql
语句if标签 where标签 choose when otherwise标签 foreach标签
快速入门
if标签
语法:
test中写判断条件 参数直接paramN或者别名 多个条件使用
and
或者or
连接只要条件成立就拼接在Sql语句中,都成立就全部都拼接
注意where子句中加上1=1来规避and的风险
如下例子:
select * from log where 1=1and outno=#{param1} and inno=#{param2}
where标签
对上面
if
标签条件判断where
连接做了处理会自动的给Sql
语句添加where
关键字,并将第一个and
去除上面sql可以改造成如下:
select * from logand outno=#{param1} and inno=#{param2}
choose when otherwise标签
类似于
Java
语法中的,case,switch
语句判断条件只要有一个成立,其他的就不会再判断了。如果没有成立的条件则默认执行
otherwise
中的内容上面sql可以改造成如下:
select * from logand outno=#{param1} and inno=#{param2} and 1=1
foreach标签
语法:
- collection:要遍历的集合对象
- item:记录每次遍历的结果
- open:在结果的左边添加内容
- separator:结果和结果之间的内容
- close:在最后添加的内容
in
查询,和批量插入
操作 如下案例:select * from account where ano in#{item} INSERT INTO t_user(id, name, password)VALUES (#{user.id}, #{user.name}, #{user.password})
其他标签使用参考点击进入·
场景案例 1.当我们需要对多张表的关联数据进行复杂动态条件查询的时候,就需要用到
if
标签进行判断 如下根据用户手机号姓名年龄性别,等进行动态条件检索,这个时候我们需要动态通过调节去拼接
sql
当条件满足sql语句加上对应条件差许select tu.USER_ID,tu.USERNAME,tu.SSEX,td.DEPT_NAME,tu.MOBILE,tu.EMAIL,tu.STATUS,tu.CREATE_TIME,td.DEPT_IDfrom t_user tu left join t_dept td on tu.DEPT_ID = td.DEPT_IDwhere tu.ADMIN_TYPE_ID> = 0 AND tu.ADMIN_TYPE_ID< = #{userParams.adminType}and (select group_concat(ur.ROLE_ID)from t_user uright join t_user_role ur on ur.USER_ID = u.USER_ID,t_role rwhere r.ROLE_ID = ur.ROLE_IDand u.USER_ID = tu.USER_ID and r.ROLE_ID=#{userParams.roleId}) AND tu.MOBILE =#{userParams.mobile} AND tu.USERNAMElike CONCAT('%',#{userParams.username},'%') AND tu.SSEX=#{userParams.ssex} AND tu.STATUS =#{userParams.status} AND td.DEPT_ID =#{userParams.deptId} AND DATE_FORMAT(tu.CREATE_TIME,'%Y%m%d') BETWEEN substring_index(#{userParams.createTime},'#',1) and substring_index(#{userParams.createTime},'#',-1)
对应mapper对应的方法
IPage findUsersByUser(Page page, @Param("userParams") SearchUserParams userParams);
对应参数实体对象
@Datapublic class SearchUserParams {private String username; private String mobile; private String status; private String ssex; private Long deptId; private String createTime; private long adminType; private String roleId; }
通过
if
标签去判断条件是否满足,满足就拼接对应sql
注意在上面我们提到的条件拼接第一个是
where
连接,而不是and
应规避and风险保证sql语法正确 如下select *from coupon cleft join user_coupon uc on c.coupon_id = uc.coupon_idWHERE 1 = 1and uc.user_id =#{couponParams.userId} and c.status =#{couponParams.status} and c.coupon_id =#{couponParams.couponId} and c.type =#{couponParams.couponType}
我们可以通过假定给他一个默认条件
WHERE 1 = 1
来解决,也可以通过嵌套where
标签来解决【mybatis的mapper特殊字符转移及动态SQL条件查询小结】到此这篇关于mybatis的mapper特殊字符转移及动态SQL条件查询的文章就介绍到这了,更多相关mybatis的mapper特殊字符转移内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 热闹中的孤独
- JAVA(抽象类与接口的区别&重载与重写&内存泄漏)
- 放屁有这三个特征的,请注意啦!这说明你的身体毒素太多
- 一个人的旅行,三亚
- 布丽吉特,人生绝对的赢家
- 慢慢的美丽
- 尽力
- 一个小故事,我的思考。
- 家乡的那条小河
- 《真与假的困惑》???|《真与假的困惑》??? ——致良知是一种伟大的力量