Mybatis--动态sql

本文介绍了Mybatis中XML映射文件的命名规则、namespace属性的使用以及如何通过if和foreach标签实现动态SQL。示例涵盖了查询、更新和批量操作的SQL编写方法。

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

XML映射文件(简单的SQL用注解,复杂的用xml)

规范:
XML映射文件的名称和Mapper接口名称一样(同包同名)注意:不能直接用.创建文件夹,用/分层
xml映射文件的namespace属性为mapper接口全限定名一致
xml映射文件的sql语句和mapper接口的方法名一致,并保持返回类型一致

xml约束
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
示例
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.demo.mapper.EmpMapper">
    <select id="select" resultType="com.example.demo.pojo.Emp">
--         resultType 单条记录封装的类型
        select * from emp where username like concat('%',#{name},'%') and gender = #{gender} order by create_time desc
    </select>
</mapper>
namespace

在这里插入图片描述

MybatisX 插件

快速定位 方便

ctrl+ALT+L SQL语句格式化(好用)

Mybatis 动态SQL

动态SQL :if 标签
示例1

查找的时候没输入条件则全部查找

select * from emp where username like concat('%',#{name},'%') and gender = #{gender} order by create_time desc

where标签可以自动去除sql中的 and where

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.demo.mapper.EmpMapper">
    <select id="select" resultType="com.example.demo.pojo.Emp">
--         resultType 单条记录封装的类型
        select * from emp
        <where>
            <if test="name != null and name!= ''">
                username like concat('%',#{name},'%')
            </if>
            <if test="gender != null">
                and gender = #{gender}
            </if>
        </where>
        order by create_time desc
    </select>
</mapper>
示例2

更新时候如果没传值会变成null -->有值更新无值不更新
set标签 能去掉sql里面的,

update emp set username =#{username},image = #{image},update_time =#{updateTime} where id =#{id}
  <update id="update">
        update emp
        <set>
            <if test="username != null">
                username=#{username},
            </if>
            <if test="image != null">
                image = #{image},
            </if>
            <if test="updateTime != null">
                update_time =#{updateTime}
            </if>
        </set>
        where id = #{id}
    </update>
动态SQL :foreach 标签

批量删除

delete from emp where id in(9,10,11);
 <delete id="deleteByIds">
        delete
        from emp
        where id in
        <!--
            collection 遍历的集合
            item 遍历出的元素
            separator 分隔符
            open 遍历开始片接前的SQL片段
            close 遍历开始片接后的SQL片段
        -->
        <foreach collection="ids" item="id" separator="," open="(" close=")">
            #{id}
        </foreach>
    </delete>
重复的sql片段
<sql id="xxx">
</sql>
<include refid="xxx">
</include>
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值