首页 > 数据库 >MyBatis系统学习(三)——动态SQL

MyBatis系统学习(三)——动态SQL

时间:2024-09-15 15:50:01浏览次数:11  
标签:name 标签 age SQL MyBatis 动态 id

MyBatis 是一款优秀的持久层框架,它通过 XML 或注解方式将 SQL 语句与 Java 对象映射起来。动态 SQL 是 MyBatis 中非常强大的功能之一,能够根据不同的条件动态生成 SQL 语句。动态 SQL 通过各种标签来灵活生成 SQL,从而避免了在代码中拼接 SQL 的复杂性和冗余性。接下来,我们会详细讲解 MyBatis 中动态 SQL 的相关知识点,涵盖动态 SQL 的元素、条件查询、更新操作及复杂查询操作。

一、MyBatis 动态 SQL 标签

动态 SQL 主要通过 MyBatis 提供的一些 XML 元素来实现,这些元素会根据传递的参数、条件等动态拼装 SQL。主要的动态 SQL 元素有:

  1. <if> 标签

    • 用于判断条件,只有当条件成立时,才会生成相应的 SQL 片段。
    • 语法:
      <if test="条件">
         SQL 语句
      </if>
      
    • 示例:
      <select id="findUser" parameterType="int" resultType="User">
        SELECT * FROM user
        WHERE 1=1
        <if test="id != null">
          AND id = #{id}
        </if>
      </select>
      
      上述 SQL 语句中,只有当 id 不为 null 时,才会拼接 AND id = #{id} 这部分 SQL。
  2. <choose>, <when>, <otherwise> 标签

    • 类似于 Java 中的 switch-case 语法,用于多条件选择。<choose> 标签包含若干 <when>,如果多个 <when> 条件都不满足,可以用 <otherwise> 作为默认的条件。
    • 语法:
      <choose>
        <when test="条件1">
          SQL 语句1
        </when>
        <when test="条件2">
          SQL 语句2
        </when>
        <otherwise>
          默认 SQL 语句
        </otherwise>
      </choose>
      
    • 示例:
      <select id="findUser" parameterType="map" resultType="User">
        SELECT * FROM user
        <where>
          <choose>
            <when test="name != null">
              name = #{name}
            </when>
            <when test="age != null">
              age = #{age}
            </when>
            <otherwise>
              status = 'active'
            </otherwise>
          </choose>
        </where>
      </select>
      
  3. <where> 标签

    • 用来自动处理 WHERE 子句前缀问题。<where> 会智能地在第一个条件前添加 WHERE,并自动去掉多余的 ANDOR
    • 示例:
      <select id="findUser" parameterType="map" resultType="User">
        SELECT * FROM user
        <where>
          <if test="name != null">
            AND name = #{name}
          </if>
          <if test="age != null">
            AND age = #{age}
          </if>
        </where>
      </select>
      
      这里,如果 nameage 都为空,<where> 标签会避免生成无效的 WHERE 子句。
  4. <set> 标签

    • 在更新操作中常用,类似于 <where><set> 也会自动处理 SET 关键字前后的逗号问题。
    • 示例:
      <update id="updateUser" parameterType="User">
        UPDATE user
        <set>
          <if test="name != null">
            name = #{name},
          </if>
          <if test="age != null">
            age = #{age},
          </if>
        </set>
        WHERE id = #{id}
      </update>
      
      在生成 SQL 时,<set> 标签会自动处理最后一项的逗号。
  5. <trim> 标签

    • trim 标签用于自定义去掉前后多余的字符,替代 whereset 标签。它有四个重要的属性:
      • prefix: SQL 片段的前缀,如 WHERESET
      • prefixOverrides: 需要去掉的前缀,如 ANDOR
      • suffix: SQL 片段的后缀。
      • suffixOverrides: 需要去掉的后缀,如 ,
    • 示例:
      <select id="findUser" parameterType="map" resultType="User">
        SELECT * FROM user
        <trim prefix="WHERE" prefixOverrides="AND">
          <if test="name != null">
            AND name = #{name}
          </if>
          <if test="age != null">
            AND age = #{age}
          </if>
        </trim>
      </select>
      
  6. <foreach> 标签

    • 用于处理集合类型的参数,比如 List数组,通常用于 IN 查询或批量插入操作。
    • 重要属性:
      • collection: 要遍历的集合,通常是 ListArray
      • item: 当前集合元素的别名。
      • separator: 元素之间的分隔符,如 ,
      • openclose: 分别表示 SQL 片段的开头和结尾字符。
    • 示例:
      <select id="findUserByIds" parameterType="list" resultType="User">
        SELECT * FROM user
        WHERE id IN
        <foreach collection="list" item="id" open="(" separator="," close=")">
          #{id}
        </foreach>
      </select>
      

二、条件查询的使用

在实际开发中,条件查询是非常常见的需求。MyBatis 中利用动态 SQL 能够灵活生成条件查询语句,通常使用 <if> 标签来控制条件的生成。

示例:简单条件查询
<select id="findUserByCondition" parameterType="User" resultType="User">
  SELECT * FROM user
  <where>
    <if test="name != null">
      AND name = #{name}
    </if>
    <if test="age != null">
      AND age = #{age}
    </if>
  </where>
</select>

在上面的例子中,只有当 nameage 不为空时,才会生成对应的条件。这样可以避免生成无效的 SQL,提升查询效率。

示例:多条件选择查询
<select id="findUserByCondition" parameterType="User" resultType="User">
  SELECT * FROM user
  <where>
    <choose>
      <when test="name != null">
        name = #{name}
      </when>
      <when test="age != null">
        age = #{age}
      </when>
      <otherwise>
        status = 'active'
      </otherwise>
    </choose>
  </where>
</select>

这个例子中,choose 标签确保只有一个条件成立时才会生成对应的 SQL。如果多个条件不成立,则使用 otherwise 语句。

三、动态更新操作

动态 SQL 在更新操作中也非常有用。通常,我们在更新时会根据实际情况只更新某些字段,而不是全部字段。MyBatis 提供了 <set> 标签来方便地生成动态更新语句。

示例:动态更新用户信息
<update id="updateUser" parameterType="User">
  UPDATE user
  <set>
    <if test="name != null">
      name = #{name},
    </if>
    <if test="age != null">
      age = #{age},
    </if>
    <if test="email != null">
      email = #{email},
    </if>
  </set>
  WHERE id = #{id}
</update>

在这个例子中,只有不为空的字段才会被更新,<set> 标签确保了 SQL 语句中不会出现多余的逗号。

四、复杂查询操作

在复杂查询中,动态 SQL 的优势更为明显。我们可以根据多种条件动态生成查询语句,并使用 join、子查询等进行复杂操作。

示例:动态查询用户及其订单
<select id="findUserWithOrders" resultMap="userOrderMap">
  SELECT u.*, o.*
  FROM user u
  LEFT JOIN orders o ON u.id = o.user_id
  <where>
    <if test="u.name != null">
      u.name = #{u.name}
    </if>
    <if test="o.status != null">
      AND o.status = #{o.status}
    </if>
  </where>
</select>

这个查询会根据用户信息和订单状态动态生成 SQL,可以方便地查询用户及其订单。

五、总结

MyBatis 的动态 SQL 为开发者提供了灵活、可扩展的 SQL 生成方式。通过使用 <if><choose><where><set><foreach> 等标签,能够根据条件动态生成 SQL,简化了代码,避免了 SQL 拼接的复杂性和冗余性。

动态 SQL 的优势在于:

  • 简化 SQL 编写:开发者可以通过 XML 或注解方式编写复杂的 SQL 逻辑。
  • 提升代码可读性:通过清晰的条件控制和 SQL 生成逻辑,代码更加清晰。
  • 减少代码冗余:避免了在 Java 代码中拼接 SQL 字符串的繁琐操作。

掌握动态 SQL 的使用对于 MyBatis 框架的实际应用非常重要,在复杂的业务逻辑中尤为常见。

标签:name,标签,age,SQL,MyBatis,动态,id
From: https://blog.csdn.net/2301_79858914/article/details/142282686

相关文章

  • 【MySQL】基础部分——DDL,DML,DQL,DCL,函数,约数,多表查询,事务
    个人学习记录,供以后回顾和复习ubuntu下安装使用1.DDL,DML,DQL,DCLDDL数据库表DML增改删DQL条件查询分组查询排序查询分页查询DCL管理用户权限控制2.函数字符串函数数值函数日期函数流程函数3.约束4.多表查询多表关系内连接外连接自连接联合查询union子查询标量子查询......
  • 商混erp系统多接口sql注入漏洞复现
    0x01漏洞描述:        商混ERP系统是一种针对混凝土行业开发的综合性企业资源规划(ERP)系统。它集成了生产、销售、采购、财务等各个方面的功能,为混凝土生产企业提供了一个全面、高效的数字化管理平台。在Operater_Action.aspx,StockreceiveEdit.aspx接口中存在sql注入,高......
  • mysql笔记8(多表查询)
    文章目录1.union联合查询可能会用到去重操作2.innerjoin内连接3.leftjoin左连接4.rightjoin右连接5.crossjoin交叉连接6.naturaljoin自然连接naturalleftjoin自然左连接naturalrightjoin自然右连接自然连接的两张表没有同名字段怎么办?7.using......
  • PostgreSQL数据库大版本升级
    简介该文档中描述的方式针对源码安装的数据进行升级操作过程1.说明 a.当前数据库版本为11.22,升级后为15.82.备份原数据库3.安装目标版本[root@olinux73_modelsws]#tar-zxfpostgresql-15.8.tar.gz[root@olinux73_modelsws]#cdpostgresql-15.8/[root@olinux73......
  • Mysql 面试题总结
    1.Mysql数据库,隔离级别有哪几个?在MySQL数据库中,事务的隔离级别决定了一个事务在执行期间对其他事务可见的数据变化情况。MySQL支持SQL标准定义的四种隔离级别,从低到高依次为:读未提交(READUNCOMMITTED)在该隔离级别下,事务中的修改即使没有提交,对其他事务也是可见的。......
  • SQL查询技巧:深入解析学生选课系统数据库
            在大学的学生选课系统中,数据库的管理和查询是日常操作中的重要部分。本文通过一系列具体的SQL查询示例,深入解析如何高效地从数据库中获取所需信息,包括学生选课情况、成绩分析、教师课程管理等。系统数据库结构首先,我们有一个包含以下表的数据库:course -存......
  • 如何解决MySQL + 字段锁表问题|如何优化MySQL DDL操作以减少锁表时间|深入理解MySQL的On
    在日常的数据库操作中,MySQL数据库的表结构修改是不可避免的操作之一。例如,添加新字段是常见的需求之一。然而,在生产环境中对表结构进行更改时,特别是在大数据量的表中,容易出现锁表问题,导致业务系统的性能下降甚至完全卡顿。MySQL在进行表结构修改时会加表级锁,从而影响到其他的查询和......
  • 掌握C#中的动态规划技术
    C#中的动态规划(DynamicProgramming,DP)是一种在数学、计算机科学和经济学中使用的,通过把原问题分解为相对简单的子问题的方式求解复杂问题的方法。动态规划通常用于优化问题,特别是那些具有重叠子问题和最优子结构性质的问题。在C#中实现动态规划算法通常涉及以下几个步......
  • 通过脚本自动部署PostgreSQL数据库
    说明该脚本部署的pg数据库为源码通过编译安装的方式执行过程[root@olinux73_model~]#chmod+x./install.sh[root@olinux73_model~]#./install.sh####清理环境####关闭防火墙####关闭Selinuxsetenforce:SELinuxisdisabled####设置PG环境变量PGBASE=/u01/appFILE_CO......
  • 获取动态页面html
    AJAXAJAX(异步JavaScript和XML)是一种无需重新加载整个页面的情况下,与服务器交换数据,将增量信息局部更新在用户界面上的技术。AJAX具有异步性,AJAX请求不会阻塞用户界面,用户可以在请求处理的同时继续与页面交互,具有更强的交互性。AJAX能使网页从浏览器请求少量信息而不是整个页面。......