app开发者平台在数字化时代的重要性与发展趋势解析
873
2022-10-09
MyBatis深入解读动态SQL的实现
目录if和wheretrimChooseSetforeach
mybatis最强大的功能之一便是它的动态sql能力
借用官方文档的一段话 : 如果您以前有使用JDBC或者类似框架的 经历,您就会明白把SQL语句条件连接在一起是多么的痛苦,要确保不能忘记空格或者不要在 columns列后面省略一个逗号等。动态语句能够完全解决掉这些痛苦。
那么如果没有这种功能到底有多痛苦呢 ? 我们来举例说明
这是一张表 , 试想如果我们通过 name 和 age来查询表信息时 , sql语句中肯定会存在 where和and字句 , 但是如果 name或者age 有一个为null或者都为null , 那么此时的 where 和and就会被孤立,那么这样肯定会出现很多问题 , 所以mybatis的动态sql功能帮助我们完美解决
MyBatis 中用于实现动态 SQL 的元素主要有:
If where trim set choose(when, otherwise) foreach
if和where
SELECT e.id,e.name ename,e.age,d.name dname FROM employee e
LEFT JOIN dept d ON e.deptId = d.id
e.name =#{name}
and e.age =#{age}
使用这种标签 , 动态sql可以根据 条件来自动帮我们完善sql
SqlSession sqlSession= MybatisUtil.getSqlSession();
EmployeeDao mapper=sqlSession.getMapper(EmployeeDao.class);
//创建一个对象,set值
Employee employee = new Employee();
employee.setName("");
employee.setAge(null);
List
System.out.println(employees);
sqlSession.commit();
sqlSession.close();
第一次我们都设置null值, 表中数据完全被查询
第二次我们只查询年龄
employee.setName("");
employee.setAge(20);
查询到两条年龄为20的数据 , 这就是mybatis动态sql的强大之处
trim
上述的 where 与 if 我们也可以使用 trim 来代替where
SELECT e.id,e.name ename,e.age,d.name dname FROM employee e
LEFT JOIN dept d ON e.deptId = d.id
e.name =#{name}
and e.age =#{age}
这里有两个属性 prefix , prefixOverrides
prefix : 代表前缀 , 如果if 中有成立的条件, 就会在sql前面拼入where字句
prefixOverrides : 根据if 条件自动判断是否去除 or | and字句
相应的也有suffix与suffixOverrides , 代表对尾部的判断
Choose
choose代表多路选择(多选一)
SELECT e.id,e.name ename,e.age,d.name dname FROM employee e
LEFT JOIN dept d ON e.deptId = d.id
and e.name =#{name}
and e.age =#{age}
and e.name ='李雷'
当
Set
set 可以根据条件自动添加set字句,动态更新列,也可以来剔除追加到条件末尾的任何不相关的逗号
update employee
name=#{name},
selnUiguN
http:// age=#{age},
where id=#{id}
foreach
– 如果传入的是单参数且参数类型是一个 List 的时候,collection 属 性值为 list
– 如果传入的是单参数且参数类型是一个 array 数组的时候, collection 的属性值为array
//创建一个list集合
List
list.add(19);
list.add(20);
List
接口方法如下 :
List
对应动态sql如下 :
SELECT e.id,e.name ename,e.age,d.name dname FROM employee e
LEFT JOIN dept d ON e.deptId = d.id where age in
selnUiguN #{age}
这里我们传入的是一个集合, 所以参数选择 list , 通过foreach我们可以动态的根据集合里的值来查询
关于动态sql就介绍到这,感谢阅读 !
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~