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语句,哈哈哈,好像有点味道喝。

测试

结果

结果正确。


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

相关推荐
zzz_23685 分钟前
【Redis】分布式锁完整演进
数据库·redis·分布式
mN9B2uk1726 分钟前
数据库的约束简介
java·数据库·sql
计算机安禾27 分钟前
【数据库系统原理】第4篇:关系数据结构的形式化定义:域、笛卡尔积与关系模式
数据结构·数据库·算法
Henry-SAP28 分钟前
SAP(ERP) BOM变更实时同步MRP方案
数据库·云原生
AI人工智能+电脑小能手29 分钟前
【大白话说Java面试题 第99题】【Mysql篇】第29题:如何选择合适的分布式主键方案?
java·数据库·分布式·mysql·面试
倔强的石头_2 小时前
kingbase备份与恢复实战(七)—— 恢复演练与验收:从“能恢复”到“可交付预案”
数据库
满昕欢喜2 小时前
第2章 SQL Server 2019服务器管理
数据库·sqlserver
giaz14n9X2 小时前
Redis 分布式锁进阶第五十一篇
数据库·redis·分布式
念越2 小时前
【数据库系统概论期末复习】第四章 数据库安全性重点与常考题整理
数据库·数据库系统概论
拾贰_C3 小时前
【mysql | windows | installation】 MySQL5.安装
数据库·windows·mysql