MyBatis-3

目录

🍊动态SQL

🍊IF标签

🍊trim标签

🍊where标签

🍊set标签

🍊foreach标签

🍊include标签


🍊动态SQL

动态sql,就是,可用性非常的高,因为你比如查询语句,你不能说按照固定的代码去实现固定的查询逻辑,就是它有可能按这个查询,也有可能按那个查询,这种是动态的,对吧,所以我们在这种复杂的场景下,就应该做到千变万化。这是我的理解。所以就需要学习标签了。

🍊IF标签

接口

对应的xml

这个if标签就是这样用的,需要注意的是,字段和values后面跟着的值,也都要加上if标签,才能确保sql语句的正确语法。

测试

我们没有设置gender的值。

结果

正确执行!

但是由于,逗号也加在了if标签里,当逗号在最后面的时候,sql语句肯定就错了,这里我不演示,所以我们就需要学习下一个标签了。

🍊trim标签

trim标签共有4个参数,是按你的需求来的,不是全都要写上。

prefix:表示整个语句块,以prefix的值作为前缀

suffix:表示整个语句块,以suffix的值作为后缀

prefixOverrides:表示整个语句块要去除掉的前缀

suffixOverrides:表示整个语句块要去除掉的后缀缀

接口

对应的xml

我们这个逗号,给它放在值的后面,因为我们的这个操作是去除整个trim标签里面的最后面的,嘛

注意我们的trim标签呢,不要在里面包裹( 和 )括号,

测试

结果

成功!

🍊where标签

就有时候啊,我们的查询语句,可能啥字段的值也不填,也就是where有时候不需要,但你有不确定,这时候,就需要用where标签了。

接口

对应的xml

where标签就直接把原本的那个sql语句的where给替换了。

测试

我们对象啥也不写,就是想让他查询整个语句。

结果

结果正确。

🍊set标签

更新操作时,set标签可以去逗号,但是set标签里面不能直接啥也没有,它那个set关键字是会保留的,这和where标签不一样。

接口

对应的xml

我们留了个age字段的更新,确保set标签里不为空,但是我这样写,其实有问题,当password不为空,可是我没有给它后面加逗号,不过对于我们来了解set标签的作用,不影响,哦,还有一点就是set标签能去除最后的那个逗号,这个我没演示,大家可以试试。

测试

结果

结果正确!

🍊foreach标签

就有时候,我们delete语句,需要批量删除,需要用到foreach标签了

接口

传递一个整数集合。

对应的xml,

这个foreach标签呢,就涉及4个参数了,

首先collection:是要和我们的接口传递的那个名字相同的,

open:以 ( 括号开头。

close: 以 )括号结尾。

separator:以逗号分割。

测试

结果

删除成功!这里表示的意思是删除了3条数据。

🍊include标签

就是这个标签,能极大的复用我们写的sql语句,

接口

对应的xml

这个sql标签,就是配合include标签来实现sql语句复用的,给它起个id名就这个名字代表这里面的整个sql语句。

include标签的refid:表示要引用的哪个sql片段

refid的英文叫改装,好像也可以这样理解,改装我们的sql语句,哈哈哈,好像有点味道喝。

测试

结果

结果正确。


完结了,又是爆肝的一天哈哈。

相关推荐
gmaajt2 小时前
CSS如何给按钮添加按下缩小的动画_利用-active配合transform
jvm·数据库·python
m0_747854522 小时前
CSS如何让响应式图片在容器内居中_利用background-position
jvm·数据库·python
笨鸟先飞的橘猫2 小时前
Mysql——MVCC学习
数据库·学习·mysql
2401_871696522 小时前
CSS如何优化移动端CSS选择器性能_遵循BEM规范避免过长嵌套
jvm·数据库·python
是宇写的啊2 小时前
MyBatis-2
数据库
2401_883600252 小时前
Cgo 回调中处理 const char- 参数的正确方法
jvm·数据库·python
m0_737539372 小时前
redis的安装
数据库·redis·缓存
zqit rdlo2 小时前
MYSQL 创建索引
数据库·mysql
gmaajt2 小时前
CSS 背景图片无法加载的常见原因与正确写法详解
jvm·数据库·python