回顾一下,在上一篇 MyBatis 之三(查询操作 占位符#{} 与 ${}、like查询、resultMap、association、collection)中,学习了针对查询操作的相关知识点,理解了占位符 #{}与 ${}的区别,还有 like 查询要使用 concat() 进行拼接,针对字段名称和属性名不同时要使用resultMap,重点学习了一对一查询用 association,一对多查询用 collection 以及这两个标签对应属性的学习
本篇将学习 MyBatis 强大特性之一的动态 SQL
动态 SQL 是 MyBatis 的强大特性之一。如果你使用过 JDBC 或其它类似的框架,你应该能理解根据不同条件拼接 SQL 语句有多痛苦,例如拼接时要确保不能忘记添加必要的空格,还要注意去掉列表最后一个列名的逗号。利用动态 SQL,可以彻底摆脱这种痛苦。
使用动态 SQL 并非一件易事,但借助可用于任何 SQL 映射语句中的强大的动态 SQL 语言,MyBatis 显著地提升了这一特性的易用性。
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kYOZDImX-1676205611731)(C:\Users\28463\AppData\Roaming\Typora\typora-user-images\1675824562270.png)]](https://img.pic99.top/hhfamen/202405/19ff5239bdb724f.png)
if 标签作用:判断一个参数是否有值,如果没值,那就会隐藏 if 中的 sql
![语法:[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7InFxK5S-1676205611731)(C:\Users\28463\AppData\Roaming\Typora\typora-user-images\1675824950223.png)]](https://img.pic99.top/hhfamen/202405/4b385db2604f810.png)
insert into userinfo(username,password,photo ) values(#{name},#{password},#{photo} )
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-oASMZXim-1676205611731)(C:\Users\28463\AppData\Roaming\Typora\typora-user-images\1675826233789.png)]](https://img.pic99.top/hhfamen/202405/e01130d1498e2c5.png)
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Wrk7OHZV-1676205611732)(C:\Users\28463\AppData\Roaming\Typora\typora-user-images\1675826554315.png)]](https://img.pic99.top/hhfamen/202405/814813a1dd92a38.png)
如果在某种情况下,所有的属性为非必填,那么你不知道哪个属性肯定会填上,按照 的做法,这就会导致可能某个字段后面出现“,”的问题
这就要考虑使用标签结合标签,对多个字段都采取动态⽣成的⽅式
标签作用:去除 SQL 语句前后多余的某个字符,其属性有
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qwFktzpB-1676205611732)(C:\Users\28463\AppData\Roaming\Typora\typora-user-images\1675827298604.png)]](https://img.pic99.top/hhfamen/202405/80a4e69df667621.png)
insert into userinfousername, password, photo values#{name}, #{password}, #{photo}
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5SS3BMbe-1676205611732)(C:\Users\28463\AppData\Roaming\Typora\typora-user-images\1675828299302.png)]](https://img.pic99.top/hhfamen/202405/f79a92ca1d41972.png)
where 标签作用:实现查询中的 where 替换,它可以实现如果没有任何的查询条件,那么它可以隐藏查询中的 where sql,但如果存在查询条件,那么会生成 where 的sql 查询,并且使用 where 标签可以自动的去除最前面的一个 and 字符
不传参数时
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-INCbnfuP-1676205611732)(C:\Users\28463\AppData\Roaming\Typora\typora-user-images\1675828929067.png)]](https://img.pic99.top/hhfamen/202405/e5b52d8f2759.png)
传参数时
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JhqMJCmA-1676205611733)(C:\Users\28463\AppData\Roaming\Typora\typora-user-images\1675829384322.png)]](https://img.pic99.top/hhfamen/202405/8d402797eb3f95e.png)
where 标签也可以使⽤ trim prefix=“where” prefixOverrides=“and” 替换
set 标签作用:进行修改操作时,配合 if 来处理非必传参数的,它的特点是会自动去除最后一个英文逗号
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Y65XJKkL-1676205611733)(C:\Users\28463\AppData\Roaming\Typora\typora-user-images\1675830578023.png)]](https://img.pic99.top/hhfamen/202405/9a55312fce687db.png)
update userinfousername=#{name}, password=#{password}, photo=#{photo} where id=#{id}
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-2FUGpdnU-1676205611733)(C:\Users\28463\AppData\Roaming\Typora\typora-user-images\1675831267788.png)]](https://img.pic99.top/hhfamen/202405/6966c64e42daa10.png)
set标签也可以使⽤ trim prefix=“set” suffixOverrides=“,” 替换
标签作用:对集合进行循环的。其属性
delete from userinfo where id in #{id}

下一篇:【离散数学】1. 数理逻辑