【MyBatis】进阶使用 (动态SQL)

动态SQL

在填写表单时,有些数据是非必填字段(例如性别,年龄等字段),那就需要在接收到参数时判断,根据参数具体的情况来生成相应的 SQL,如果参数不为 null,就插入到数据里,如果参数为 null,就根据具体表设计而定。

<if>

使用 <if> 标签可以完成对接收到的参数进行判断。

首先看一组都不为空的情况下:

再看当性别为 null 的情况:

此时我们就需要使用 <if> 标签对接收到的参数进行判断,如果不为空,就加入到数据库:

而数据库也能正常插入数据:

<trim>

上述只判断了一个字段 gender,如果有更多的字段则需要使用多个 <if> 标签:

若字段 phone 为 null,则会出现下面这个情况:

此时,我们就需要 <trim> 标签了,用来去除不必要的 逗号:

在 <trim> 标签里还有两个配置,prefix 和 suffix,一个用于补全前缀,一个用于补全后缀:

<where>

<where> 标签用来去除判断条件里的 and 和 or,若筛选条件都为 null,则会去除 where 关键字。

当两个条件都不为 null 时:

当其中一个判断条件为 null 时:

当判断条件全为 null 时:

<set>

<set> 标签也常用于去除逗号,如果接受到的参数不为 null,则更新数据。

当参数都不为 null 时:

其中一个为 null 时:

参数都为 null 时:

<foreach>

用于对集合进行遍历。

collection 为方法中的集合
item 为集合中的每个对象
open 为语句块开头的字符串
close 则为语句块结束的字符串
separate 为每次遍历之间间隔的字符串

<include>

在编写 SQL 语句时,可能会存在重复的语句, 为解决这个现象,可以使用 <sql> 标签对相同语句进行封装,再使用 <include> 标签进行引用。

相关推荐
Leo.yuan3 分钟前
不同数据仓库模型有什么不同?企业如何选择适合的数据仓库模型?
大数据·数据库·数据仓库·信息可视化·spark
麦兜*19 分钟前
MongoDB 6.0 新特性解读:时间序列集合与加密查询
数据库·spring boot·mongodb·spring·spring cloud·系统架构
chat2tomorrow22 分钟前
数据采集平台的起源与演进:从ETL到数据复制
大数据·数据库·数据仓库·mysql·低代码·postgresql·etl
稻草人想看远方25 分钟前
关系型数据库和非关系型数据库
数据库
考虑考虑26 分钟前
Postgerssql格式化时间
数据库·后端·postgresql
千里码aicood34 分钟前
【springboot+vue】党员党建活动管理平台(源码+文档+调试+基础修改+答疑)
java·数据库·spring boot
Chan1638 分钟前
【智能协同云图库】基于统一接口架构构建多维度分析功能、结合 ECharts 可视化与权限校验实现用户 / 管理员图库统计、通过 SQL 优化与流式处理提升数据
java·spring boot·后端·sql·spring·intellij-idea·echarts
TDengine (老段)1 小时前
TDengine 选择函数 Max() 用户手册
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
驾驭人生1 小时前
Asp .Net Core 系列:Asp .Net Core 集成 Hangfire+MySQL
数据库·mysql·.netcore
float_六七1 小时前
预编译SQL:安全与性能的双重保障
sql·安全·oracle