学习的最大理由是想摆脱平庸,早一天就多一份人生的精彩;迟一天就多一天平庸的困扰。各位小伙伴,如果您:
想系统/深入学习某技术知识点…
一个人摸索学习很难坚持,想组团高效学习…
想写博客但无从下手,急需写作干货注入能量…
热爱写作,愿意让自己成为更好的人…
文章目录
前言
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>
//测试类publicvoidgetEmpByCondition() { 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>
publicvoidgetEmpByChoose() { 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>
publicvoiddeleteMoreByArray() { SqlSessionsqlSession=SqlSessionUtils.getSqlSession(); DynamicSQLMappermapper=sqlSession.getMapper(DynamicSQLMapper.class); intresult=mapper.deleteMoreByArray(newInteger[]{6, 7, 8, 9}); System.out.println(result); }
- 批量添加
<!--intinsertMoreByList( ("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>
publicvoidinsertMoreByList() { 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的相关知识点,希望对你有所帮助。
积跬步以至千里,积怠惰以至深渊。时代在这跟着你一起努力哦!