MyBatis:动态SQL

news2025/7/14 15:36:57

文章目录

  • 动态SQL
    • if标签
    • trim标签
    • where标签
    • set标签
    • foreach标签
    • include标签和sql标签

Mybatis动态SQL的官方文档: https://mybatis.net.cn/dynamic-sql.html

动态SQL

动态SQL是 MyBatis的强大特性之一,如果是使用JDBC根据不同条件拼接sql很麻烦,例如拼接时要确保不能忘记添加必要的空格,还要注意去掉列表最后一个列名的逗号。利用动态 SQL,可以彻底摆脱这种痛苦。

if标签

使用场景:在我们数据库表中字段分为必填字段和非必填字段,对与非必填字段数据库会自动帮我们赋值,那如果在添加用户的时候有不确定的字段传入,程序应该如何实现呢?
这个时候就需要使用动态标签来判断了,比如添加的时候性别gender为非必填字段

 <insert id="insertUserByCondition">
        INSERT INTO user_info (
        username,
        age,
        <if test="gender != null">
            gender,
        </if>
        password)
        VALUES (
        #{username},
        #{age},
        <if test="gender != null">
            #{gender},
        </if>
        #{password})
</insert>

可不可以不进行判断,直接把字段设置为null呢?
不可以,这种情况下,如果gender字段有默认值,就会设置为默认值
在这里插入图片描述
在这里插入图片描述
测试代码

    @Test
  void insertUserByCondition() {
        UserInfo userInfo=new UserInfo();
        userInfo.setUsername("username5");
        userInfo.setPassword("password5");
        userInfo.setGender(5);
        userInfo.setAge(5);
        userInfoMapperXML.insertUserByCondition(userInfo);

    }

在这里插入图片描述
不设置gender的参数,也可以进行插入

在这里插入图片描述

在这里插入图片描述
注意:

  1. if标签test中的属性是传入对象中的属性,不是数据库字段
  2. 插入语句中,values中赋值也要有if标签,要一一对应,gender字段中有if标签,values中也要的gender属性也要有if标签

trim标签

标签中有如下属性:
• prefix:表示整个语句块,以prefix的值作为前缀
• suffix:表示整个语句块,以suffix的值作为后缀
• prefixOverrides:表示整个语句块要去除掉的前缀
• suffixOverrides:表示整个语句块要去除掉的后缀

trim标签的使用
sql语句

insert into user_info ( username, password, age, gender ) values("username5","password5",5,5)
     insert into user_info
        <trim suffixOverrides="," prefix="(" suffix=")">
            <if test="username!=null">
                username,
            </if>
            <if test="password!=null">
                password,
            </if>
            <if test="age!=null">
                age,
            </if>

            <if test="gender!=null">
                gender
            </if>
        </trim>
        values (
        <trim  suffixOverrides="," prefix="(" suffix=")">
            <if test="username!=null">
                #{username},
            </if>
            <if test="password!=null">
                #{password},
            </if>
            <if test="age!=null">
                #{age},
            </if>
            <if test="gender!=null">
                #{gender}
            </if>
        </trim>

        )

    </insert>

测试代码

  @Test
    void insertUserByCondition() {
        UserInfo userInfo=new UserInfo();
        userInfo.setUsername("username5");
        userInfo.setPassword("password5");
        userInfo.setGender(5);
        userInfo.setAge(5);
        userInfoMapperXML.insertUserByCondition(userInfo);

    }

在这里插入图片描述

where标签

看下⾯这个场景,系统会根据我们的筛选条件,动态组装where条件

在这里插入图片描述
这个是怎么实现的呢?通过where标签

举个例子
sql语句:

select* from user_info where age=1 and gender =2
  <select id="selectByCondition" resultType="com.example.demo.model.UserInfo">
        select id, username, age, gender, phone, delete_flag, create_time,
        update_time
        from user_info where
            <if test="age != null">
                 age = #{age}
            </if>
            <if test="gender != null">
                and gender = #{gender}
            </if>

</select>

当if标签有一个或两个不符合条件的时候,会报错,这时候where标签就派上用场了

<select id="selectByCondition" resultType="com.example.demo.model.UserInfo">
        select id, username, age, gender, phone, delete_flag, create_time,
        update_time
        from user_info where
        <where>
            <if test="age != null">
                 age = #{age}
            </if>
            <if test="gender != null">
                and gender = #{gender}
            </if>
		</where>

</select>

测试代码

    @Test
   void selectByCondition() {
        UserInfo userInfo=new UserInfo();
        userInfo.setAge(16);
        userInfoMapperXML.selectByCondition(userInfo);
    }

在这里插入图片描述
where标签只会在子元素有内容的情况下才插入where子句,而且会自动去除子句的开头的AND或OR

set标签

sql

update user_info set password="123" ,gender= 4 where id=34
<update id="updateUser2">
        update user_info set
        <if test="username!=null">
            username=#{username}
        </if>
        <if test="password!=null">
            ,password=#{password}
        </if>
        <if test="gender!=null">
            ,gender=#{gender}
        </if>
        where  id=#{id}

    </update>

如果我们写出这样的xml文件,当我们的username为null时,sql语法错误,多了一个逗号

下面是报错信息
在这里插入图片描述
set标签会删除额外的逗号,并把set插入sql语句中

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

    </update>

测试代码

@Test
    void updateUser2() {
        UserInfo userInfo=new UserInfo();
        userInfo.setPassword("123");
        userInfo.setGender(4);

```java
        userInfo.setId(34);
        userInfoMapperXML.updateUser2(userInfo);
    }

在这里插入图片描述

foreach标签

foreach 元素的功能非常强大,它允许你指定一个集合,声明可以在元素体内使用的集合项(item)和索引(index)变量。它也允许你指定开头与结尾的字符串以及集在这里插入代码片合项迭代之间的分隔符。这个元素也不会错误地添加多余的分隔符!

foreach 标签有如下属性:

collection:绑定方法参数中的集合,如 List,Set,Map或数组对象
item:遍历时的每⼀个对象
open:语句块开头的字符串
close:语句块结束的字符串
separator:每次遍历之间间隔的字符串
举个例子:批量查询id为12,13,14的数据

sql:

 select * from user_info where id in ( 12 , 13 ,14)
<select id="selectUserByIds" resultType="com.example.demo.model.UserInfo">
        select * from user_info where id in
        <foreach collection="ids" item="id"  separator="," open="(" close=")">
            #{id}
        </foreach>
    </select>

测试代码

    @Test
    void selectUserByIds() {
        List<Integer> ids=new ArrayList<>();
        ids.add(12);
        ids.add(13);
        ids.add(14);
        userInfoMapperXML.selectUserByIds(ids);
    }

在这里插入图片描述
需求:批量删除id为12,13,14的数据


    <delete id="deleteByIds">
        delete from user_info where id in
        <foreach collection="ids" item="id" separator="," open="(" close=")" >
            #{id}
    </foreach>
    </delete>

测试代码

 @Test
    void deleteByIds() {
        List<Integer> ids=List.of(12,13,14);
        userInfoMapperXML.deleteByIds(ids);
    }

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

include标签和sql标签

在xml映射文件中配置的SQL,有时可能会存在很多重复的片段,此时就会存在很多冗余的代码
在这里插入图片描述

sql 标签: 定义可重用的SQL片段
include 标签:通过属性refid,指定包含的SQL片段

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

    <select id="selectAll" resultType="com.example.demo.model.UserInfo">
        SELECT
        <include refid="allColumn"></include>
        FROM `user_info`
        </select>

测试代码

  @Test
    void selectAll() {
        userInfoMapperXML.selectAll().stream().forEach(x-> System.out.println(x));
    }

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2379904.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

游戏引擎学习第280天:精简化的流式实体sim

回顾并为今天的内容做铺垫 今天的任务是让之前关于实体存储方式的改动真正运行起来。我们现在希望让实体系统变得更加真实和实用&#xff0c;能够支撑我们游戏实际所需的功能。这就要求我们对它进行更合理的实现和调试。 昨天我们基本让代码编译通过了&#xff0c;但实际上还…

王树森推荐系统公开课 排序03:预估分数融合

融合预估分数 p c l i c k ⋅ p l i k e p_{click} \cdot p_{like} pclick​⋅plike​ 有实际意义&#xff0c;等于在曝光中点赞的概率。 p c l i c k ⋅ p c o l l e c t p_{click} \cdot p_{collect} pclick​⋅pcollect​ 同理。 按多种排名做 ensemble sort。 某电商的融…

网络I/O学习-poll(三)

一、为什么要用Poll 由于select参数太多&#xff0c;较于复杂&#xff0c;调用起来较为麻烦&#xff1b;poll对其进行了优化 二、poll机制 poll也是一个系统调用&#xff0c;每次调用都会将所有客户端的fd拷贝到内核空间&#xff0c;然后进行轮询&#xff0c;判断IO是否就绪…

k8s(12) — 版本控制和滚动更新(金丝雀部署理念)

金丝雀部署简介&#xff1a; 1、基本概念 金丝雀部署是一种软件开发中的渐进式发布策略&#xff0c;其核心思想是通过将新版本应用逐步发布给一小部分用户&#xff08;即 “金丝雀” 用户&#xff09;&#xff0c;在真实环境中验证功能稳定性和性能表现&#xff0c;再逐步扩大发…

Google设置app-ads.txt

问题&#xff1a; 应用上架后admob后台显示应用广告投放量受限&#xff0c;需要设置app-ads.txt才行。 如何解决&#xff1a; 官方教程: 看了下感觉不难&#xff0c;创建一个txt&#xff0c;将第二条的代码复制进行就得到app-ads.txt了。 然后就是要把这个txt放到哪才可以…

docker安装rockerMQ

参考Docker部署RocketMQ5.x (单机部署配置参数详解不使用docker-compose直接部署)_rocketmq不推荐用docker部署-CSDN博客 镜像拉取 镜像地址&#xff1a; https://hub.docker.com/r/apache/rocketmq/tags 我在部署的时候最新发行版是5.1.0可以根据需求自行选择一个5.x的版本&a…

交叉引用、多个参考文献插入、跨文献插入word/wps中之【插入[1-3]、连续文献】

我们在写论文时&#xff0c;需要插入大量参考文献。 有时&#xff0c;一句话需要引用多个文献&#xff0c;如&#xff1a;[1-3]或者[1,3,4]这种形式多个文献插入、跨文献插入。 在上一篇文章中&#xff0c;我们提到可以直接打“-”或者“&#xff0c;”&#xff0c;但是word导出…

PLC双人舞:profinet转ethernet ip网关奏响施耐德与AB的协奏曲

PLC双人舞&#xff1a;ethernet ip转profinet网关奏响施耐德与AB的协奏曲 案例分析&#xff1a;施耐德PLC与AB PLC的互联互通 在现代工业自动化中&#xff0c;设备之间的互联互通至关重要。本案例旨在展示如何通过北京倍讯科技的EtherNet/IP转Modbus网关&#xff0c;将施耐德P…

缺乏团队建设活动,如何增强凝聚力?

当一个团队缺乏系统性的建设活动时&#xff0c;成员之间容易产生疏离感、误解与信任缺失&#xff0c;最终影响整体执行力和目标达成。要有效增强团队凝聚力&#xff0c;应从设计高参与感的团队活动、结合业务与人文目标、营造持续共创的文化机制、推动跨层级协作互动等层面着手…

力扣HOT100之二叉树:230. 二叉搜索树中第 K 小的元素

这道题直接用最笨的办法来做的&#xff0c;用递归来做&#xff0c;我们定义一个全局变量vector<int> element&#xff0c;然后使用中序遍历&#xff0c;每当碰到一个非空节点就将其加入到向量中&#xff0c;这样依赖当向量中的元素小于k时&#xff0c;就返回0&#xff0c…

Linux面试题集合(5)

把文件1的内容追加到文件2 cat 文件1>>文件2 把文件1和文件2合并成文件3 cat 文件1 文件2>文件3 使用less查看文件时&#xff0c;搜寻ab字符 /ab 用more和less如何查看文件 more&#xff1a; CtrlF -- 向下滚动一屏 CtrlB -- 返回上一屏 f -- 向下翻屏 b -- 向上翻屏 …

python动漫论坛管理系统

目录 技术栈介绍具体实现截图系统设计研究方法&#xff1a;设计步骤设计流程核心代码部分展示研究方法详细视频演示试验方案论文大纲源码获取/详细视频演示 技术栈介绍 Django-SpringBoot-php-Node.js-flask 本课题的研究方法和研究步骤基本合理&#xff0c;难度适中&#xf…

Web 技术与 Nginx 网站环境部署

这里写目录标题 一. Web基础域名和DNS域名的概念域名的结构域名结构类型 Hosts文件Hosts文件的作用修改Hosts文件 DNS域名注册 网页与HTML网页概述HTML概述HTML基本标签HTML语法规则HTML文件结构 网站和主页Web1.0 与 Web2.0 静态网页与动态网页静态网页动态网页动态网页语言 H…

FP8精度革命:Hopper架构下大模型训练的误差传播控制方法

点击 “AladdinEdu&#xff0c;同学们用得起的【H卡】算力平台”&#xff0c;H卡级别算力&#xff0c;按量计费&#xff0c;灵活弹性&#xff0c;顶级配置&#xff0c;学生专属优惠。 一、FP8为何成为大模型训练的新范式&#xff1f; 1.1 算力需求与精度演进的矛盾 当前大语言…

手动制做一个Transformer

本文来自I made a transformer by hand . 一直以来&#xff0c;笔者对 transformer 的注意力机制、qkv的理解都浮于表面&#xff0c;当然也不是说我看完 I made a transformer by hand 后理解有多深入&#xff0c;但确实加深了我对相关概念的理解&#xff0c;故搬运此文章&…

已解决——如何让网站实现HTTPS访问?

一、申请SSL证书 SSL证书是HTTPS实现的关键&#xff0c;它由受信任的证书颁发机构&#xff08;CA&#xff09;签发&#xff0c;用于验证网站的身份并加密数据传输。以下是申请SSL证书的常见步骤&#xff1a; 选择证书类型 根据网站的需求和预算&#xff0c;选择合适的SSL证书…

WebRTC技术EasyRTC嵌入式音视频通信SDK助力智能电视搭建沉浸式实时音视频交互

一、方案概述​ EasyRTC是一款基于WebRTC技术的开源实时音视频通信解决方案&#xff0c;具备低延迟、高画质、跨平台等优势。将EasyRTC功能应用于智能电视&#xff0c;能够为用户带来全新的交互体验&#xff0c;满足智能电视在家庭娱乐、远程教育、远程办公、远程医疗等多种场…

小乌龟git中的推送账户、作者账户信息修改

文章目录 修改git文档作者信息修改git推送用户信息参考文献 修改git文档作者信息 小乌龟中的用户信息为&#xff1a;作者信息&#xff0c;并非推送用户。 上边用户信息&#xff0c;修改的是文件的作者信息。如果想要修改git服务中记录的推送用户信息需要修改推送用户信息。 …

Kubernetes MCP服务器(K8s MCP):如何使用?

#作者&#xff1a;曹付江 文章目录 1、什么是 Kubernetes MCP 服务器&#xff1f;1.1、K8s MCP 服务器 2、开始前的准备工作2.1. Kubernetes集群2.2. 安装并运行 kubectl2.3. Node.js 和 Bun2.4. &#xff08;可选&#xff09;Helm v3 3、如何设置 K8s MCP 服务器3.1. 克隆存储…

R²AIN SUITE 亮相第九届智能工厂高峰论坛

2025年5月16日&#xff0c;在圆满落幕的第九届智能工厂高峰论坛上&#xff0c;上海比孚信息科技有限公司携自主研发的 RAIN SUITE 企业AI应用中台解决方案亮相展会。本次论坛以"从互联工厂到智慧工厂"为主题&#xff0c;吸引了400余位行业专家、制造企业代表及产业链…