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
相关推荐
欧恩意22 分钟前
【Tools】Java反汇编工具推荐
java·汇编
寻星探路1 小时前
【JVM 终极通关指南】万字长文从底层到实战全维度深度拆解 Java 虚拟机
java·开发语言·jvm·人工智能·python·算法·ai
lbb 小魔仙1 小时前
【Java】Java 实战项目:手把手教你写一个电商订单系统
android·java·python
星河耀银海1 小时前
Java安全开发实战:从代码防护到架构安全
java·安全·架构
青云交1 小时前
Java 大视界 -- 基于 Java 的大数据可视化在城市水资源管理与节水策略制定中的应用
java·java 大数据·java 大数据可视化·城市水资源管理·spark 数据清洗·echarts 热力图·管网漏损控制
人间打气筒(Ada)1 小时前
Linux学习~日志文件参考
linux·运维·服务器·学习·日志·log·问题修复
紫陌涵光1 小时前
112. 路径总和
java·前端·算法
浅念-1 小时前
C/C++内存管理
c语言·开发语言·c++·经验分享·笔记·学习
workflower1 小时前
多变量时间序列预测
java·hadoop·nosql·需求分析·big data·结对编程
凌晨7点2 小时前
DSP学习F28004x数据手册:第13章-ADC
单片机·嵌入式硬件·学习