目录
🍊动态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语句,哈哈哈,好像有点味道喝。
测试

结果

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