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
相关推荐
hopetomorrow3 分钟前
学习路之压力测试--jmeter安装教程
学习·jmeter·压力测试
hopetomorrow4 分钟前
学习路之PHP--使用GROUP BY 发生错误 SELECT list is not in GROUP BY clause .......... 解决
开发语言·学习·php
郑祎亦13 分钟前
Spring Boot 项目 myblog 整理
spring boot·后端·java-ee·maven·mybatis
不是二师兄的八戒14 分钟前
本地 PHP 和 Java 开发环境 Docker 化与配置开机自启
java·docker·php
爱编程的小生25 分钟前
Easyexcel(2-文件读取)
java·excel
/**书香门第*/32 分钟前
Cocos creator 3.8 支持的动画 7
学习·游戏·游戏引擎·游戏程序·cocos2d
带多刺的玫瑰42 分钟前
Leecode刷题C语言之统计不是特殊数字的数字数量
java·c语言·算法
美式小田1 小时前
单片机学习笔记 9. 8×8LED点阵屏
笔记·单片机·嵌入式硬件·学习
猫爪笔记1 小时前
前端:HTML (学习笔记)【2】
前端·笔记·学习·html
计算机毕设指导61 小时前
基于 SpringBoot 的作业管理系统【附源码】
java·vue.js·spring boot·后端·mysql·spring·intellij-idea