Mybatis之动态SQL

简介: 【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的相关知识点,希望对你有所帮助。

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

相关文章
|
SQL Java 数据库连接
【YashanDB知识库】解决mybatis的mapper文件sql语句结尾加分号";"报错
【YashanDB知识库】解决mybatis的mapper文件sql语句结尾加分号";"报错
|
8月前
|
SQL XML Java
通过MyBatis的XML配置实现灵活的动态SQL查询
总结而言,通过MyBatis的XML配置实现灵活的动态SQL查询,可以让开发者以声明式的方式构建SQL语句,既保证了SQL操作的灵活性,又简化了代码的复杂度。这种方式可以显著提高数据库操作的效率和代码的可维护性。
488 18
|
SQL Java 数据库连接
MyBatis动态SQL字符串空值判断,这个细节99%的程序员都踩过坑!
本文深入探讨了MyBatis动态SQL中字符串参数判空的常见问题。通过具体案例分析,对比了`name != null and name != &#39;&#39;`与`name != null and name != &#39; &#39;`两种写法的差异,指出后者可能引发逻辑混乱。为避免此类问题,建议在后端对参数进行预处理(如trim去空格),简化MyBatis判断逻辑,提升代码健壮性与可维护性。细节决定成败,严谨处理参数判空是写出高质量代码的关键。
1597 0
|
8月前
|
SQL Java 数据库连接
SSM相关问题-1--#{}和${}有什么区别吗?--Mybatis都有哪些动态sql?能简述一下动 态sql的执行原理吗?--Spring支持的几种bean的作用域 Scope
在MyBatis中,`#{}`是预处理占位符,可防止SQL注入,适用于大多数参数传递场景;而`${}`是直接字符串替换,不安全,仅用于动态表名、列名等特殊场景。二者在安全性、性能及使用场景上有显著区别。
325 0
|
11月前
|
SQL XML Java
菜鸟之路Day35一一Mybatis之XML映射与动态SQL
本文介绍了MyBatis框架中XML映射与动态SQL的使用方法,作者通过实例详细解析了XML映射文件的配置规范,包括namespace、id和resultType的设置。文章还对比了注解与XML映射的优缺点,强调复杂SQL更适合XML方式。在动态SQL部分,重点讲解了`&lt;if&gt;`、`&lt;where&gt;`、`&lt;set&gt;`、`&lt;foreach&gt;`等标签的应用场景,如条件查询、动态更新和批量删除,并通过代码示例展示了其灵活性与实用性。最后,通过`&lt;sql&gt;`和`&lt;include&gt;`实现代码复用,优化维护效率。
1065 5
|
SQL Java 数据库连接
【YashanDB 知识库】解决 mybatis 的 mapper 文件 sql 语句结尾加分号";"报错
【YashanDB 知识库】解决 mybatis 的 mapper 文件 sql 语句结尾加分号";"报错
|
SQL 缓存 Java
框架源码私享笔记(02)Mybatis核心框架原理 | 一条SQL透析核心组件功能特性
本文详细解构了MyBatis的工作机制,包括解析配置、创建连接、执行SQL、结果封装和关闭连接等步骤。文章还介绍了MyBatis的五大核心功能特性:支持动态SQL、缓存机制(一级和二级缓存)、插件扩展、延迟加载和SQL注解,帮助读者深入了解其高效灵活的设计理念。
|
SQL XML Java
九、MyBatis动态SQL
九、MyBatis动态SQL
230 2
|
SQL Java 数据库连接
【潜意识Java】MyBatis中的动态SQL灵活、高效的数据库查询以及深度总结
本文详细介绍了MyBatis中的动态SQL功能,涵盖其背景、应用场景及实现方式。
1802 6
|
SQL XML Java
六、MyBatis特殊的SQL:模糊查询、动态设置表名、校验名称唯一性
六、MyBatis特殊的SQL:模糊查询、动态设置表名、校验名称唯一性
449 0
下一篇
开通oss服务