Java学习-MyBatis学习(五)

代码下载

动态SQL
  • 动态SQL技术是一种根据特定条件动态拼装SQL语句的功能,它存在的意义是为了解决拼接SQL语句字符串时的痛点问题
if
  • 根据标签中test属性对应的判断条件,判断下面语句是否拼接到SQL语句中
xml 复制代码
<!--List<Emp> getEmpByCondition(Emp emp);-->
    <select id="getEmpByConditionOne" resultType="Emp">
        <!--if根据标签中test属性对应的判断条件,判断下面语句是否拼接到SQL语句中-->
        select * from t_emp where 1 = 1
        <if test="empName != null and empName !=''">
            emp_name = #{empName}
        </if>
        <if test="age != null and age !=''">
            and age = #{age}
        </if>
        <if test="sex != null and sex !=''">
            and sex = #{sex}
        </if>
        <if test="email != null and email !=''">
            and email = #{email}
        </if>
    </select>
where
  • 当where标签中有内容时,会自动生成where关键字,并能去除多余的and或or标签
  • 当where标签中无内容时,此时where标签没有任何效果
  • 注:where标签不能将其中内容后面多余的and或or去除
xml 复制代码
<select id="getEmpByConditionTwo" resultType="Emp">
        <!--
            where:当where标签中有内容时,会自动生成where关键字,并能去除多余的and或or标签
                    当where标签中无内容时,此时where标签没有任何效果
                    注:where标签不能将其中内容后面多余的and或or去除-->
        select * from t_emp
       <where>
           <if test="empName != null and empName !=''">
               emp_name = #{empName}
           </if>
           <if test="age != null and age !=''">
               and age = #{age}
           </if>
           <if test="sex != null and sex !=''">
               and sex = #{sex}
           </if>
           <if test="email != null and email !=''">
               and email = #{email}
           </if>
       </where>
    </select>
trim
  • prefix|suffix:将trim标签中内容前面和后面添加指定内容
  • suffixOverrides|prefixOverrides:将trim标签中内容前面或后面去掉指定内容
  • 若标签中没有内容时,trim标签没有任何效果
xml 复制代码
 <select id="getEmpByConditionThree" resultType="Emp">
        <!--
           trim:
           prefix|suffix:将trim标签中内容前面和后面添加指定内容
           suffixOverrides|prefixOverrides:将trim标签中内容前面或后面去掉指定内容
           若标签中没有内容时,trim标签没有任何效果
           -->
        select * from t_emp
        <trim prefix="where" suffixOverrides="and|or">
            <if test="empName != null and empName !=''">
                emp_name = #{empName} and
            </if>
            <if test="age != null and age !=''">
                 age = #{age} and
            </if>
            <if test="sex != null and sex !=''">
                 sex = #{sex} and
            </if>
            <if test="email != null and email !=''">
                 email = #{email}
            </if>
        </trim>
    </select>
choose,when,otherwise
  • 相当于if...else if...else
  • when至少有一个,otherwise最多只能有一个
xml 复制代码
 <!--List<Emp> getEmpByChoose(Emp emp);-->
    <!-- 设置SQL片断-->
    <sql id="empColumns">
        eid,emp_name,age,sex,email
    </sql>
    <select id="getEmpByChoose" resultType="Emp">
        <!--
           choose,when,otherwise相当于if..else if..else
           when至少有一个,otherwise最多只能有一个
           -->
        <!-- include引用SQL片断-->
        select <include refid="empColumns"/> from t_emp
        <where>
            <choose>
                <when test="empName != null and empName !=''">
                    emp_name=#{empName}
                </when>
                <when test="age != null and age !=''">
                    age=#{age}
                </when>
                <when test="sex != null and sex !=''">
                    sex=#{sex}
                </when>
                <when test="email != null and email !=''">
                    email=#{email}
                </when>
                <otherwise>
                    did = 1
                </otherwise>
            </choose>
        </where>
    </select>
foreach
  • collection:设置需要循环的数组或集合
  • item:表示数组或集合中每一个数据
  • sperator:循环之间分割符
  • open:foreach标签所循环的所有内容的开始符
  • close:foreach标签所循环的所有内容的结束符
xml 复制代码
 <!--
    foreach
     collection:设置需要循环的数组或集合
     item:表示数组或集合中每一个数据
     sperator:循环之间分割符
     open:foreach标签所循环的所有内容的开始符
     close:foreach标签所循环的所有内容的结束符
    -->
    <!--int deleteMoreByArray(@Param("eids") Integer[] eids);-->
    <delete id="deleteMoreByArrayOne">
        delete from t_emp where eid in
        <foreach collection="eids" item="eid" separator="," open="(" close=")">
            #{eid}
        </foreach>
    </delete>
    <delete id="deleteMoreByArray">
        delete from t_emp where eid in
        <foreach collection="eids" item="eid" separator="or" open="(" close=")">
            eid = #{eid}
        </foreach>
    </delete>
    <!--int insertMoreByList(List<Emp> emps);-->
    <insert id="insertMoreByList">
        insert into t_emp values
        <foreach collection="emps" item="emp" separator=",">
            (null,#{emp.empName},#{emp.age},#{emp.sex},#{emp.email},null)
        </foreach>
    </insert>
sql
  • 设置SQL片断
xml 复制代码
 <sql id="empColumns">
        eid,emp_name,age,sex,email
    </sql>
       
  • 引用SQL片断
xml 复制代码
 <!-- include引用SQL片断-->
select <include refid="empColumns"/> from t_emp
相关推荐
mucheni3 分钟前
迅为RK3568开发板OpeHarmony学习开发手册-修改应用程序名称
linux·前端·学习
Moe4884 分钟前
ConcurrentHashMap 重要方法实现原理和源码解析(一)
java·后端
拾忆,想起28 分钟前
Dubbo核心架构全解析:构建微服务通信的高速公路
java·微服务·云原生·架构·dubbo·哈希算法
YJlio34 分钟前
进程和诊断工具学习笔记(8.19):Hyper-V 来宾调试与符号配置 —— 在虚拟化场景下用 LiveKd 抓现场
网络·笔记·学习
楠枬38 分钟前
Spring Cloud 概述
java·spring cloud·微服务
♡喜欢做梦38 分钟前
MyBatis操作数据库(入门)
java·数据库·mybatis
q***d1731 小时前
微服务与单体架构的成本对比
java·微服务·架构
冻感糕人~1 小时前
Agent框架协议“三部曲”:MCP、A2A与AG-UI的协同演进
java·人工智能·学习·语言模型·大模型·agent·大模型学习
阿Y加油吧1 小时前
java并发编程面试题精讲——day02
java·面试·c#
ArabySide1 小时前
【Spring Boot】基于MyBatis的条件分页
java·spring boot·后端·mybatis