zoukankan      html  css  js  c++  java
  • mybatis提取<where><if>共用代码

      mybatis项目dao层中很多sql语句都会拥有某些相同的查询条件,以<where><if test=""></if></where>的形式拼接在sql语句后,一个两个的sql语句感觉不到什么,但是如果查询语句特别多,但是查询的条件总是类似的,那就可以考虑把<where><if>这部分代码抽取出来,封装一下,然后需要条件搜索的sql语句直接引用就可以了。

      先来看下没有抽取代码之前的条件sql语句

    复制代码
    第一条
    <select id = "getUserEmailByProvinceAndOrderType" resultType="String">
            select DISTINCT(wo_responsibility) from t_view_workorder
            <where>
                <if test="province != '全国' and province != null">
                    wo_province = #{province}
                </if>
                <if test="orderType != '全部' and orderType != null">
                    and wo_type = #{orderType}
                </if>
                <if test="email != ''">
                    and wo_responsibility = #{email}
                </if>
            </where>
    </select>
    第二条
    <select id = "getUndoneDelayOrderByProvinceAndOrderTypeAndUserEmail" resultType="com.chinamobile.sias.workorder.po.Workorder">
            select * from t_view_workorder
            <where>
            <if test="province != '全国' and province != null">
                    wo_province = #{province}
                </if>
                <if test="orderType != '全部' and orderType != null">
                    and wo_type = #{orderType}
                </if>
                <if test="email != ''">
                    and wo_responsibility = #{email}
                </if>
            <if test="true"> and (wo_complete_time is null or wo_complete_time='') and (select curdate()) >= wo_regulations_time </if>

        </where>

    </select>
    复制代码

    以上是两条sql语句,可以看出,两个sql语句中有某些查询条件是相同的

    复制代码
            <if test="province != '全国' and province != null">
                wo_province = #{province}
            </if>
            <if test="orderType != '全部' and orderType != null">
                and wo_type = #{orderType}
            </if>
            <if test="email != ''">
                and wo_responsibility = #{email}
            </if>    
    复制代码

    此时我们就可以对此段判断条件进行提取。如下:

    复制代码
    <sql id="common_where_if">
            <if test="province != '全国' and province != null">
                wo_province = #{province}
            </if>
            <if test="orderType != '全部' and orderType != null">
                and wo_type = #{orderType}
            </if>
            <if test="email != ''">
                and wo_responsibility = #{email}
            </if>
    </sql>
    复制代码

    此时把<where>标签下相同的判断条件提去了出来,id自己取,这里定为 common_where_if.

    那么如何使用这段代码呢,如下:

    <include refid="common_where_if"/>

    格式如下:

    复制代码
    <select id = "getUserEmailByProvinceAndOrderType" resultType="String">
            select DISTINCT(wo_responsibility) from t_view_workorder
            <where>
                <include refid="common_where_if"/>
            </where>
    
    </select>
    复制代码

    此时就在<where>标签中引用了共用的判断条件,再多的sql语句,再多的查询条件,只需要一个<include>就能解决重复的代码。

  • 相关阅读:
    Sona && Little Elephant and Array && Little Elephant and Array && D-query && Powerful array && Fast Queries (莫队)
    P1494 [国家集训队]小Z的袜子(luogu)
    【题解】洛谷P1311 [NOIP2011TG] 选择客栈(递推)
    【题解】洛谷P2296 [NOIP2014TG] 寻找道路(SPFA+DFS)
    【题解】洛谷P2661 [NOIP2015TG] 信息传递
    【题解】洛谷P1065 [NOIP2006TG] 作业调度方案(模拟+阅读理解)
    【题解】洛谷P1032 [NOIP2002TG]字串变换(BFS+字符串)
    [BZOJ2127]happiness-[网络流-最小割]
    [BZOJ3218]a + b Problem-[主席树+网络流-最小割]
    BZOJ4049][CERC2014]Mountainous landscape-[线段树+凸包+二分]
  • 原文地址:https://www.cnblogs.com/exmyth/p/8085572.html
Copyright © 2011-2022 走看看