MyBatis高级特性

Posted 华哥好棒棒

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MyBatis高级特性相关的知识,希望对你有一定的参考价值。

动态sql 复用sql语句

    1.定义sql片段
        <sql id="xxx_column">被复用的片段</sql>
    2.引用sql片段
        <include refid="xxx_column"></include>

 

动态sql 简化查询

DAO简化
  将所有可能查询的参数,封装成XxxQuery对象

 

where标签+if标签 动态查询

核心:调用dao方法传入参数不同,决定了sql的条件不同
动态sql:一个sql标签,由于传入参数不同,实际执行的sql语句也不同
        
        <!--where标签代替where关键词-->
        <where>
            <if test="dao方法参数的属性名   表达式判断(且and、或or、逻辑运算符、equals)">
                dao方法参数的属性名 = #{dao方法参数的属性名}
            </if>
            <if test="id != null and !id.equals(‘‘)"></if>
        </where>


update+if标签 动态修改

set标签:
    1.代替set关键字
    2.自动忽略修改列后面多余的  逗号

if标签:
    test="dao方法的参数属性是否有值"
语法:
    <if test="参数属性名 != null ">
        ...修改sql  ,
    </if> 

 

forEach标签 动态删除

接口的方法:
    void delete(@Param("ids")String[] ids);

mapper文件:
    conllection:被遍历的参数值
    item:数组遍历过程中每个元素值的名字
    <delete id="delete" >
        delete from t_student where id in
        <foreach collection="ids" item="id" open="(" separator="," close=")">
            #{id}
        </foreach>
    </delete>

 

rim标签

作用:
    1.可以替代任何关键字(where set)
    2.可以忽略任何特殊字符(and  ,)

 

以上是关于MyBatis高级特性的主要内容,如果未能解决你的问题,请参考以下文章

MYBATIS05_ifwherechoosewhentrimsetforEach标签sql片段

推荐学java——MyBatis高级

推荐学java——MyBatis高级

推荐学java——MyBatis高级

推荐学java——MyBatis高级

推荐学java——MyBatis高级