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
相关推荐
瀚高PG实验室8 分钟前
HGDB集群(安全版)repmgr手动切换主备库
java·数据库·安全·瀚高数据库
刘新明198919 分钟前
Frida辅助分析OLLVM虚假控制流程(下)
java·开发语言·前端
澄澈i23 分钟前
CMake学习篇[3]---CMake进阶+嵌套CMakeLists+多层级关系
c++·学习·cmake
Camellia031128 分钟前
为第二次考核的电控学习
学习
茯苓gao36 分钟前
电路学习(一)
学习
第二只羽毛41 分钟前
重载和继承的实践
java·开发语言
王嘉俊9251 小时前
设计模式--适配器模式:优雅解决接口不兼容问题
java·设计模式·适配器模式
王嘉俊9251 小时前
设计模式--组合模式:统一处理树形结构的优雅设计
java·设计模式·组合模式
道19931 小时前
50 台小型无人车与50套穿戴终端 5 公里范围内通信组网方案深度研究
java·后端·struts
迎風吹頭髮1 小时前
UNIX下C语言编程与实践35-UNIX 守护进程编写:后台执行、脱离终端、清除掩码与信号处理
java·c语言·unix