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
相关推荐
小池先生2 分钟前
springboot启动不了 因一个spring-boot-starter-web底下的tomcat-embed-core依赖丢失
java·spring boot·后端
CodeClimb5 分钟前
【华为OD-E卷-木板 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
odng8 分钟前
IDEA自己常用的几个快捷方式(自己的习惯)
java·ide·intellij-idea
CT随16 分钟前
Redis内存碎片详解
java·开发语言
brrdg_sefg25 分钟前
gitlab代码推送
java
奶香臭豆腐38 分钟前
C++ —— 模板类具体化
开发语言·c++·学习
hanbarger1 小时前
mybatis框架——缓存,分页
java·spring·mybatis
cdut_suye1 小时前
Linux工具使用指南:从apt管理、gcc编译到makefile构建与gdb调试
java·linux·运维·服务器·c++·人工智能·python
苹果醋31 小时前
2020重新出发,MySql基础,MySql表数据操作
java·运维·spring boot·mysql·nginx
小蜗牛慢慢爬行1 小时前
如何在 Spring Boot 微服务中设置和管理多个数据库
java·数据库·spring boot·后端·微服务·架构·hibernate