MYBATIS常用标签和动态查询

本文深入探讨MyBatis框架中的动态SQL特性,包括if、where、set、choose、foreach等标签的使用方法及场景,解析如何通过这些标签提高SQL语句的灵活性和效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

大家好,我是IT修真院深圳分院第15期的JAVA学员,一枚正直纯洁善良的JAVA程序员。今天给大家分享一下,修真院官网Java任务1,深度思考中的知识点JDBC连接池原理

一、背景介绍

之前刚开始学的时候都是从JDBC开始,就是那几个固定的步骤,加载驱动,创建连接、建立语句这些,这些都是辅助性的手段,大家准备工作做好以后,才能执行SQL语句进行CURD的操作。当然我们写的时候一个表就要把这些东西全部写一遍,十分痛苦。MyBatis就出来了,他是一个持久层的框架,能减少这些重复性的工作,通过mybatis提供的映射方式,自由灵活的生成满足需要的sql语句。MyBatis可以将向preparedStatement中的输入参数自动进行输入映射,将查询结果集灵活映射成java对象

二、知识剖析

动态SQL是MyBatis最强大的特性之一。用于实现动态SQL的主要元素如下:

  1. if标签
  2. where标签
  3. set标签
  4. choose标签
  5. foreach标签

if标签

if是mybatis动态SQL中的判断元素,有点类似于Java中的if语句,不同的是这里的if一般常常和test配合使用。

当用户传入的address不为null或者空字符串的时候,会有语句错误,这个时候就需要加入where标签

where标签

where标签经常跟if标签搭配使用,where标签会判断if标签里的条件是否成立,如果有条件成立则会拼接执行该条件下的sql语句。where标签避免所有条件都为空的时候出现“select * from user where ”这种会出错的情况,当然我们也可以在where后面加入“1=1”简单的解决。

set标签

set标签与where标签类似,set标签一般用在update语句中,当我们在update语句里碰到多个字段相关的问题,在这种情况下我们就会用到set标签,他也是判断if标签里的条件是否成立,然后拼接执行sql语句。相当好使。

choose标签

相比于if标签二选一,choose标签就有了第三种选择,或者更多的选择,在映射器的动态语句中使用choose…when…otherwise…这三个元素就能满足不同的业务要求,Mybatis会根据参数的设置进行判断,来拼接组装sql语句,当when标签下无满足条件,则会执行otherwise标签里的语句。

foreach标签

foreach元素是一个循环语句,他的作用是遍历集合,他能够很好的支持数组和List的集合。并对此提供遍历,foreach标签常用于in这样的语法里,进行批量处理,增删改查都可以。

三、常见问题

if标签与choose标签的区别

四、解决方案

if是不管条件成不成立都会执行下一条if;而choose中,如果when中先执行的语句,则不会再往后执行。

五、编码实战

<!--if查询-->
<select id="ListIf" resultType="com.jnshu.entity.Student">
    select * from student
    <!--加判断条件-->
    <if test="name !=null">
        where name like concat('%',#{name},'%')
    </if>
    <!--第一个条件为空的时候,多条件查询会出错-->
    <if test="weight != null">
        and weight > #{weight}
    </if>
</select>

<!--where标签会进行自动判断,如果任何条件都不成立,那么就在SQL语句不会出现where关键字。如果有任何条件成立,会自动去掉多余的-->
<select id="ListWhere" resultType="com.jnshu.entity.Student">
    select * from student
    <where>
        <if test="name !=null">
            and name like concat('%',#{name},'%')
        </if>
        <if test="weight != null">
            and weight > #{weight}
        </if>
    </where>
</select>

<update id="Update" parameterType="com.jnshu.entity.Student">
  UPDATE student
    <set>
        <if test="name !=null">
            name = #{name},
        </if>
        <if test="weight !=null">
            weight = #{weight},
        </if>
    </set>
  where id = #{id}
</update>

<!--MyBatis里面没有else标签,但是可以使用when otherwise标签来达到类似的目的-->
<select id="ListChoose" resultType="com.jnshu.entity.Student" >
    select * from student
    <where>
        <choose>
            <when test="name != null">
                and name like concat('%',#{name},'%')
            </when>
            <when test="weight != null">
                and weight > #{weight}
            </when>
            <otherwise>
                and id &lt; #{id}
            </otherwise>
        </choose>
    </where>
</select>

<select id="ListForeach" resultType="com.jnshu.entity.Student">
    select * from student
    where name IN
    <foreach collection="list"  item="item" open="(" separator="," close=")">
        #{item}
    </foreach>
</select>

六、扩展思考

1.动态SQL还有哪种实现方式?

2.不同版本mybaits使用动态SQL时的差别?

七、参考文献

https://blog.youkuaiyun.com/jpzhu16/article/details/52810747

八、更多讨论

Q1:为什么要使用动态查询
A1:加入用户想查询一个字段那就需要模糊查询,所以我们就使用动态查询,判断用户输入的内容进行相应的查询。

Q2:平时我们插入不用动态标签页没有什么问题
A2:这是因为平时我们不设默认值,一旦设定默认值,还是要使用动态插入的

Q3:标签只能用户update吗?
A3:没有错,因为sql语句本身的set本来就是用于update语句

感谢原作者的文章,此教程是在他之前技术分享的基础上完善而成。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值