Mybatis之动态SQL

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
可观测可视化 Grafana 版,10个用户账号 1个月
简介: 【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的相关知识点,希望对你有所帮助。

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

相关文章
|
4天前
|
SQL XML Java
mybatis 调用修改SQL时 出现了一个问题 没有修改成功也没有报错
mybatis 调用修改SQL时 出现了一个问题 没有修改成功也没有报错
13 0
|
1月前
Mybatis+mysql动态分页查询数据案例——测试类HouseDaoMybatisImplTest)
Mybatis+mysql动态分页查询数据案例——测试类HouseDaoMybatisImplTest)
21 1
|
1月前
|
Java 关系型数据库 数据库连接
Mybatis+MySQL动态分页查询数据经典案例(含代码以及测试)
Mybatis+MySQL动态分页查询数据经典案例(含代码以及测试)
28 1
|
1月前
Mybatis+mysql动态分页查询数据案例——条件类(HouseCondition)
Mybatis+mysql动态分页查询数据案例——条件类(HouseCondition)
15 1
|
1月前
Mybatis+mysql动态分页查询数据案例——分页工具类(Page.java)
Mybatis+mysql动态分页查询数据案例——分页工具类(Page.java)
23 1
|
1月前
Mybatis+mysql动态分页查询数据案例——房屋信息的实现类(HouseDaoMybatisImpl)
Mybatis+mysql动态分页查询数据案例——房屋信息的实现类(HouseDaoMybatisImpl)
22 2
|
1月前
Mybatis+mysql动态分页查询数据案例——工具类(MybatisUtil.java)
Mybatis+mysql动态分页查询数据案例——工具类(MybatisUtil.java)
15 1
|
18天前
|
Java 关系型数据库 MySQL
【mybatis-plus】自定义多数据源,动态切换数据源事务失效问题
【mybatis-plus】自定义多数据源,动态切换数据源事务失效问题
【mybatis-plus】自定义多数据源,动态切换数据源事务失效问题
|
1月前
|
Java 数据库连接 mybatis
Mybatis+mysql动态分页查询数据案例——Mybatis的配置文件(mybatis-config.xml)
Mybatis+mysql动态分页查询数据案例——Mybatis的配置文件(mybatis-config.xml)
20 1
|
1月前
Mybatis+mysql动态分页查询数据案例——配置映射文件(HouseDaoMapper.xml)
Mybatis+mysql动态分页查询数据案例——配置映射文件(HouseDaoMapper.xml)
15 1

热门文章

最新文章

  • 1
    Serverless 应用引擎产品使用之在函数计算中,数据库访问失败如何解决
    4
  • 2
    Serverless 应用引擎产品使用之在阿里云函数计算中发现没有NAC(Native Application Component)选项,且无法自己上传MOD(模块)如何解决
    4
  • 3
    Serverless 应用引擎操作报错合集之在阿里云函数计算中,调用了FC函数但是没有执行或者报错,并且在FC函数后台也看不到调用记录日志如何解决
    5
  • 4
    Serverless 应用引擎操作报错合集之在阿里函数计算中,sd部署启动报错CAExited 报错信息“operation not permitted”如何解决
    4
  • 5
    Serverless 应用引擎操作报错合集之在阿里函数计算中,SD Controlnet Depth 运行过程中出现错误“urllib3 v2.0 only supports OpenSSL 1.1.1+”如何解决
    5
  • 6
    Serverless 应用引擎操作报错合集之在阿里云函数计算中,laravel zip包使用示例的start.sh脚本启动时出现错误代码如何解决
    5
  • 7
    Serverless 应用引擎操作报错合集之在阿里云函数计算中,服务器调用FC函数时出现 "[Errno -3] Temporary failure in name resolution)" 错误如何解决
    4
  • 8
    Serverless 应用引擎操作报错合集之在Serverless 应用引擎中,部署过程中遇到错误代码如何解决
    8
  • 9
    Serverless 应用引擎操作报错合集之在 Serverless 应用引擎中,遇到“没法通过 head 传递灰度标识”如何解决
    5
  • 10
    Serverless 应用引擎操作报错合集之在阿里函数计算中,函数执行超时,报错Function time out after如何解决
    11