Mybatis之动态SQL

本文涉及的产品
任务调度 XXL-JOB 版免费试用,400 元额度,开发版规格
函数计算FC,每月15万CU 3个月
应用实时监控服务-用户体验监控,每月100OCU免费额度
简介: 【1月更文挑战第4天】Mybatis框架的动态SQL技术是一种根据特定条件动态拼装SQL语句的功能,它存在的意义是为了解决拼接SQL语句字符串时的痛点问题


学习的最大理由是想摆脱平庸,早一天就多一份人生的精彩;迟一天就多一天平庸的困扰。各位小伙伴,如果您:

想系统/深入学习某技术知识点…

一个人摸索学习很难坚持,想组团高效学习…

想写博客但无从下手,急需写作干货注入能量…

热爱写作,愿意让自己成为更好的人…

文章目录

前言

一、if

二、where

三、trim

四、choose、when、otherwise

五、foreach

六、SQL片段

总结


前言

Mybatis框架的动态SQL技术是一种根据特定条件动态拼装SQL语句的功能,它存在的意义是为了解决拼接SQL语句字符串时的痛点问题


一、if

  • if标签可通过test属性(即传递过来的数据)的表达式进行判断,若表达式的结果为true,则标签中的内容会执行;反之标签中的内容不会执行
  • 在where后面添加一个恒成立条件1=1
  • 这个恒成立条件并不会影响查询的结果
  • 这个1=1可以用来拼接and语句,例如:当empName为null时
  • 如果不加上恒成立条件,则SQL语句为select * from t_emp where and age = ? and sex = ? and email = ?,此时where会与and连用,SQL语句会报错
  • 如果加上一个恒成立条件,则SQL语句为select * from t_emp where 1= 1 and age = ? and sex = ? and email = ?,此时不报错
<!--List<Emp>getEmpByCondition(Empemp);--><selectid="getEmpByCondition"resultType="Emp">select*fromt_empwhere1=1<iftest="empName != null and empName !=''">andemp_name=#{empName}
</if><iftest="age != null and age !=''">andage=#{age}
</if><iftest="sex != null and sex !=''">andsex=#{sex}
</if><iftest="email != null and email !=''">andemail=#{email}
</if></select>

二、where

  • where和if一般结合使用:
  • 若where标签中的if条件都不满足,则where标签没有任何功能,即不会添加where关键字
  • 若where标签中的if条件满足,则where标签会自动添加where关键字,并将条件最前方多余的and/or去掉
<!--List<Emp>getEmpByCondition(Empemp);--><selectid="getEmpByCondition"resultType="Emp">select*fromt_emp<where><iftest="empName != null and empName !=''">emp_name=#{empName}
</if><iftest="age != null and age !=''">andage=#{age}
</if><iftest="sex != null and sex !=''">andsex=#{sex}
</if><iftest="email != null and email !=''">andemail=#{email}
</if></where></select>
  • 注意:where标签不能去掉条件后多余的and/or
<!--这种用法是错误的,只能去掉条件前面的and/or,条件后面的不行--><iftest="empName != null and empName !=''">emp_name=#{empName} and</if><iftest="age != null and age !=''">age=#{age}
</if>

三、trim

  • trim用于去掉或添加标签中的内容
  • 常用属性
  • prefix:在trim标签中的内容的前面添加某些内容
  • suffix:在trim标签中的内容的后面添加某些内容
  • prefixOverrides:在trim标签中的内容的前面去掉某些内容
  • suffixOverrides:在trim标签中的内容的后面去掉某些内容
  • 若trim中的标签都不满足条件,则trim标签没有任何效果,也就是只剩下select * from t_emp
<!--List<Emp>getEmpByCondition(Empemp);--><selectid="getEmpByCondition"resultType="Emp">select*fromt_emp<trimprefix="where"suffixOverrides="and|or"><iftest="empName != null and empName !=''">emp_name=#{empName} and</if><iftest="age != null and age !=''">age=#{age} and</if><iftest="sex != null and sex !=''">sex=#{sex} or</if><iftest="email != null and email !=''">email=#{email}
</if></trim></select>
//测试类@TestpublicvoidgetEmpByCondition() {
SqlSessionsqlSession=SqlSessionUtils.getSqlSession();
DynamicSQLMappermapper=sqlSession.getMapper(DynamicSQLMapper.class);
List<Emp>emps=mapper.getEmpByCondition(newEmp(null, "张三", null, null, null, null));
System.out.println(emps);
}

四、choose、when、otherwise

  • choose、when、otherwise相当于if...else if..else
  • when至少要有一个,otherwise至多只有一个
<selectid="getEmpByChoose"resultType="Emp">select*fromt_emp<where><choose><whentest="empName != null and empName != ''">emp_name=#{empName}
</when><whentest="age != null and age != ''">age=#{age}
</when><whentest="sex != null and sex != ''">sex=#{sex}
</when><whentest="email != null and email != ''">email=#{email}
</when><otherwise>did=1</otherwise></choose></where></select>
@TestpublicvoidgetEmpByChoose() {
SqlSessionsqlSession=SqlSessionUtils.getSqlSession();
DynamicSQLMappermapper=sqlSession.getMapper(DynamicSQLMapper.class);
List<Emp>emps=mapper.getEmpByChoose(newEmp(null, "张三", 23, "男", "123@qq.com", null));
System.out.println(emps);
}

  • 相当于if a else if b else if c else d,只会执行其中一个

五、foreach

  • 属性:
  • collection:设置要循环的数组或集合
  • item:表示集合或数组中的每一个数据
  • separator:设置循环体之间的分隔符,分隔符前后默认有一个空格,如,
  • open:设置foreach标签中的内容的开始符
  • close:设置foreach标签中的内容的结束符
  • 批量删除
<!--intdeleteMoreByArray(Integer[] eids);--><deleteid="deleteMoreByArray">deletefromt_empwhereeidin<foreachcollection="eids"item="eid"separator=","open="("close=")">#{eid}
</foreach></delete>
@TestpublicvoiddeleteMoreByArray() {
SqlSessionsqlSession=SqlSessionUtils.getSqlSession();
DynamicSQLMappermapper=sqlSession.getMapper(DynamicSQLMapper.class);
intresult=mapper.deleteMoreByArray(newInteger[]{6, 7, 8, 9});
System.out.println(result);
}

  • 批量添加
<!--intinsertMoreByList(@Param("emps") List<Emp>emps);--><insertid="insertMoreByList">insertintot_empvalues<foreachcollection="emps"item="emp"separator=",">        (null,#{emp.empName},#{emp.age},#{emp.sex},#{emp.email},null)
</foreach></insert>
@TestpublicvoidinsertMoreByList() {
SqlSessionsqlSession=SqlSessionUtils.getSqlSession();
DynamicSQLMappermapper=sqlSession.getMapper(DynamicSQLMapper.class);
Empemp1=newEmp(null,"a",1,"男","123@321.com",null);
Empemp2=newEmp(null,"b",1,"男","123@321.com",null);
Empemp3=newEmp(null,"c",1,"男","123@321.com",null);
List<Emp>emps=Arrays.asList(emp1, emp2, emp3);
intresult=mapper.insertMoreByList(emps);
System.out.println(result);
}

六、SQL片段

  • sql片段,可以记录一段公共sql片段,在使用的地方通过include标签进行引入
  • 声明sql片段:<sql>标签
<sqlid="empColumns">eid,emp_name,age,sex,email</sql>
  • 引用sql片段:<include>标签
<!--List<Emp>getEmpByCondition(Empemp);--><selectid="getEmpByCondition"resultType="Emp">select<includerefid="empColumns"></include>fromt_emp</select>

总结

以上就是Mybatis之动态SQL的相关知识点,希望对你有所帮助。

积跬步以至千里,积怠惰以至深渊。时代在这跟着你一起努力哦!

目录
打赏
0
2
2
1
16
分享
相关文章
|
8天前
|
九、MyBatis动态SQL
九、MyBatis动态SQL
21 2
|
4天前
|
六、MyBatis特殊的SQL:模糊查询、动态设置表名、校验名称唯一性
六、MyBatis特殊的SQL:模糊查询、动态设置表名、校验名称唯一性
20 0
3、Mybatis-Plus 自定义sql语句
这篇文章介绍了如何在Mybatis-Plus框架中使用自定义SQL语句进行数据库操作。内容包括文档结构、编写mapper文件、mapper.xml文件的解释说明、在mapper接口中定义方法、在mapper.xml文件中实现接口方法的SQL语句,以及如何在单元测试中测试自定义的SQL语句,并展示了测试结果。
3、Mybatis-Plus 自定义sql语句
【潜意识Java】MyBatis中的动态SQL灵活、高效的数据库查询以及深度总结
本文详细介绍了MyBatis中的动态SQL功能,涵盖其背景、应用场景及实现方式。
136 6
|
3月前
|
mybatis实现动态sql
MyBatis的动态SQL功能为开发人员提供了强大的工具来应对复杂的查询需求。通过使用 `<if>`、`<choose>`、`<foreach>`等标签,可以根据不同的条件动态生成SQL语句,从而提高代码的灵活性和可维护性。本文详细介绍了动态SQL的基本用法和实际应用示例,希望对您在实际项目中使用MyBatis有所帮助。
116 11
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
canal-starter 监听解析 storeValue 不一样,同样的sql 一个在mybatis执行 一个在数据库操作,导致解析不出正确对象
canal-starter 监听解析 storeValue 不一样,同样的sql 一个在mybatis执行 一个在数据库操作,导致解析不出正确对象
mybatis使用四:dao接口参数与mapper 接口中SQL的对应和对应方式的总结,MyBatis的parameterType传入参数类型
这篇文章是关于MyBatis中DAO接口参数与Mapper接口中SQL的对应关系,以及如何使用parameterType传入参数类型的详细总结。
97 10
mybatis复习03,动态SQL,if,choose,where,set,trim标签及foreach标签的用法
文章介绍了MyBatis中动态SQL的用法,包括if、choose、where、set和trim标签,以及foreach标签的详细使用。通过实际代码示例,展示了如何根据条件动态构建查询、更新和批量插入操作的SQL语句。
mybatis复习03,动态SQL,if,choose,where,set,trim标签及foreach标签的用法
Mybatis系列之 Error parsing SQL Mapper Configuration. Could not find resource com/zyz/mybatis/mapper/
文章讲述了在使用Mybatis时遇到的资源文件找不到的问题,并提供了通过修改Maven配置来解决资源文件编译到target目录下的方法。
Mybatis系列之 Error parsing SQL Mapper Configuration. Could not find resource com/zyz/mybatis/mapper/

云原生

+关注