【Mybatis】动态 SQL:代码与数据的灵动共舞,奏响数据库查询的华丽乐章

embedded/2025/2/11 17:44:32/

前言

🌟🌟本期讲解关于Spring IOC&DI的详细介绍~~~

🌈感兴趣的小伙伴看一看小编主页:GGBondlctrl-CSDN博客

🔥 你的点赞就是小编不断更新的最大动力                                       

🎆那么废话不多说直接开整吧~~

目录

📚️1.动态SQL

1.1标签><if>标签

1.2<trim>标签

1.3<where>标签

1.4标签><set>标签

1.5<foreach>标签

1.6<include>标签

📚️2.总结


 

📚️1.动态SQL

动态 SQL 是Mybatis的强⼤特性之⼀,能够完成不同条件下不同的 sql 拼接可以参考官⽅⽂档:

网址在这里:动态 SQL_MyBatis中文网

1.1<if>标签

我们在平时登录的时候会出现如下的情况:

注册分为两种字段:必填字段和⾮必填字段,那如果在添加⽤⼾的时候有不确定的字段传⼊,程序应该如何实现呢?
这个时候就需要使⽤动态标签 来判断了,⽐如添加的时候性别 gender 为⾮必填字段,具体实现如
下:

<select id="select4" resultType="com.example.mybatis.Model.UserInfo">select user_name,password,age from user_info<trim prefix="where" prefixOverrides="and"><if test="username!=null">username=#{username}</if><if test="password!=null">and password=#{password}</if><if test="age!=null">and age=#{age}</if></trim></select>

解释:

这里加另一个标签,这里小编后面进行解释,具体的意思就是,where条件后,如果这里的user_name没有进行输入就不按照这里的user_name进行查询,其他几个也是一样的,若存在这里对应的参数,那么就按照这里的条件,没有就不会存在这里的参数;

我们在test类中进行测试:

 @Testvoid select4() {UserInfo userInfo=new UserInfo();userInfo.setAge(19);userInfoXMLMapper.select4(userInfo);}

解释:

这里设置的就是Age存在参数,其他的没有那么这里的查询的条件就是age=19的数据,然后进行查询,可以看到前面存在and,若username为空,那么后面就会多出来一个and,那么如何进行处理呢?

1.2<trim>标签

之前的插⼊⽤⼾功能,只是有⼀个 gender 字段可能是选填项,如果有多个字段,⼀般考虑使⽤标签结合标签,对多个字段都采取动态⽣成的⽅式。
标签中有如下属性:

• prefix:表⽰整个语句块,以prefix的值作为前缀
• suffix:表⽰整个语句块,以suffix的值作为后缀
• prefixOverrides:表⽰整个语句块要去除掉的前缀
• suffixOverrides:表⽰整个语句块要去除掉的后缀

例如下面的插入的操作:

<insert id="insert2">insert into user_info<trim prefix="(" suffix=")" suffixOverrides=","><if test="username!=null">username,</if><if test="password!=null">password,</if><if test="age!=null">age</if></trim>values<trim prefix="(" suffix=")" suffixOverrides=","><if test="username!=null">#{username},</if><if test="password!=null">#{password},</if><if test="age!=null">#{age}</if></trim></insert>

解释:

1.insert id=“”,这里的名字就是表示的进行数据接收的方法名,

2.在进行insert into user_info后就是进行动态SQL的操作,以<trim>标签开始:

基于 prefix 配置,开始部分加上 (
• 基于 suffix 配置,结束部分加上 )
• 多个 组织的语句都以 , 结尾,在最后拼接好的字符串还会以 , 结尾,会基于
suffixOverrides 配置去掉最后⼀个 ,

3.if标签开始,进行判断输入的参数是否为空,如果存在就进行条件的添加,如果没有,那么就不会添加这里的条件;

4.每个test里的属性就表示的就是对象传入的属性,注意不是数据库的字段

1.3<where>标签

咱们还是先试用,然后进行讲解,具体的代码如下所示:

 <select id="selectByUser" resultType="com.example.mybatis.Model.UserInfo">select * from user_info <where><if test="username !=null">user_name=#{username}</if><if test="age !=null">and age=#{age}</if></where></select>

解释:

这里小编这里只列举了几个属性,那么where标签的使使用就是可以代替上述的<trim>标签

<where> 只会在⼦元素有内容的情况下才插⼊where⼦句,⽽且会⾃动去除⼦句的开头的AND或
OR

以上标签也可以使⽤ <trim prefix="where" prefixOverrides="and"> 替换, 但是此种情况下, 当⼦元素都没有内容时, where关键字也会保留 

1.4<set>标签

具体的实例代码如下所示:

 <update id="update">update user_info<set>          <if test="username!=null">username=#{username},</if><if test="password!=null">password=#{password},</if><if test="age!=null">age=#{age}</if> </set>where id=#{id}</update>

解释:<set>标签的作用:

<set> :动态的在SQL语句中插⼊set关键字,并会删掉额外的逗号. (⽤于update语句中)
以上标签也可以使⽤ <trim prefix="set" suffixOverrides=","> 替换;

1.5<foreach>标签

对集合进⾏遍历时可以使⽤该标签。标签有如下属性:

• collection:绑定⽅法参数中的集合,如 List,Set,Map或数组对象
• item:遍历时的每⼀个对象
• open:语句块开头的字符串
• close:语句块结束的字符串
• separator:每次遍历之间间隔的字符串

具体的代码实例就是如下的:

<delete id="deleteByIdInteger">delete from user_infowhere id in<foreach collection="intance" item="id" open="(" close=")" separator=",">#{id}</foreach></delete>

解释:

这里就是SQL的意思就是

delete from user_info where id in (11, 12, 13)

instanc就是列表的名字,id可以理解为数据库字段,id= #{id}; 

1.6<include>标签

 在我们编写SQL的时候存在,重复的语句,就会有很多冗余的代码。例如:

我们可以对重复的代码⽚段进⾏抽取,将其通过 <sql> 标签封装到⼀个SQL⽚段,然后再通过
<include> 标签进⾏引⽤。

• <sql> :定义可重⽤的SQL⽚段
• <include> :通过属性refid,指定包含的SQL⽚段 

<sql id="allColumn">id, username, age, gender, phone, delete_flag, create_time, update_time
</sql>

 然后在进行使用时:

<select id="queryAllUser" resultMap="BaseMap">select<include refid="allColumn"></include>from userinfo
</select>

解释:

此时即时我们将这里的查询的数据库字段进行了封装,取名叫做allcolumn,然后再使用的时候使用<include>标签进行SQL片段的使用;

📚️2.总结

本期小编主要讲解了动态SQL的使用,具体包括<if><trim><where><set><forearch><include>标签,主要还是使用,概念不是很重要

🌅🌅🌅~~~~最后希望与诸君共勉,共同进步!!!


💪💪💪以上就是本期内容了, 感兴趣的话,就关注小编吧。

       😊😊  期待你的关注~~~


http://www.ppmy.cn/embedded/161383.html

相关文章

MongoDB 的使用场景

一、内容管理系统 1. 博客平台 文章内容、作者信息、标签、评论等数据结构多样&#xff0c;MongoDB 的无模式特性可轻松应对。比如 WordPress 等博客系统&#xff0c;使用 MongoDB 能灵活存储不同格式和长度的文章内容&#xff0c;以及与文章相关的各种元数据。 2. 新闻网站…

PostgreSQL 18新特性之DML语句RETURNING增强

PostgreSQL 很早就支持 DML 语句的 RETURNING 子句&#xff0c;用于返回插入、更正或者删除的数据。例如&#xff1a; CREATE TABLE t(id int, v numeric); INSERT INTO t(id, v) VALUES(1,1); INSERT INTO t(id, v) VALUES(2,5); INSERT INTO t(id, v) VALUES(3,10);UPDATE t…

wordpressAI工具,已接入Deepseek 支持自动生成文章、生成图片、生成长尾关键词、前端AI窗口互动、批量采集等

基于关键词或现有内容生成SEO优化的文章&#xff0c;支持多种AI服务&#xff08;如OpenAI、百度文心一言、智谱AI等&#xff09;&#xff0c;并提供定时任务、内容采集、关键词生成等功能。 核心功能 文章生成 关键词生成&#xff1a;根据输入的关键词生成高质量文章。 内容…

唯一值校验的实现思路(续)

本文接着上一篇文章《唯一值校验的实现思路》&#xff0c;在后端实现唯一值校验。用代码实现。 /*** checkUniqueException[唯一值校验]** param entity 新增或编辑的学生实体* param insert 是否新增&#xff0c;如果是传入true&#xff1b;反之传入false* return void* date…

WPS计算机二级•文档的文本样式与编号

听说这是目录哦 标题级别❤️新建文本样式 快速套用格式&#x1fa77;设置标题样式 自定义设置多级编号&#x1f9e1;使用自动编号&#x1f49b;取消自动编号&#x1f49a;设置 页面边框&#x1f499;添加水印&#x1fa75;排版技巧怎么分栏&#x1f49c;添加空白下划线&#x…

安当SLA操作系统登录双因素认证:全方位保障Windows系统登录安全

一、产品概述 在当今数字化时代&#xff0c;Windows系统面临着诸多安全挑战&#xff0c;如弱口令问题等。安当SLA&#xff08;System Login Agent&#xff09;作为一款强大的双因素登录认证产品&#xff0c;通过支持OTP动态口令和USBKey硬件令牌认证&#xff0c;有效解决多种W…

【Linux第二章】Linux内核与权限

【Linux第二章】Linux内核与权限 Linux内核&#x1f9d0; 1.内核简述✨ Linux内核是操作系统的“心脏”&#xff0c;它直接与电脑的硬件&#xff08;CPU、内存、硬盘等&#xff09;打交道。它不仅负责CPU资源调度&#xff0c;也管理资源拷贝、转移&#xff0c;甚至动一下鼠标…

Java项目: 基于SpringBoot+mybatis+maven+mysql实现的装饰工程管理系统(含源码+数据库+毕业论文)

一、项目简介 本项目是一套基于SpringBootmybatismavenmysql实现的装饰工程管理系统 包含&#xff1a;项目源码、数据库脚本等&#xff0c;该项目附带全部源码可作为毕设使用。 项目都经过严格调试&#xff0c;eclipse或者idea 确保可以运行&#xff01; 该系统功能完善、界面…