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

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

mybatis提取<where><if>共用代码
第一条
<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>
mybatis提取<where><if>共用代码

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

mybatis提取<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>    
mybatis提取<where><if>共用代码

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

mybatis提取<where><if>共用代码
<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>
mybatis提取<where><if>共用代码

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

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

<include ref/>

格式如下:

mybatis提取<where><if>共用代码
<select id = "getUserEmailByProvinceAndOrderType" resultType="String">
        select DISTINCT(wo_responsibility) from t_view_workorder
        <where>
            <include ref/>
        </where>

</select>
mybatis提取<where><if>共用代码

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

相关文章:

  • 2021-12-28
  • 2022-12-23
  • 2022-12-23
  • 2021-05-28
  • 2021-05-17
  • 2021-10-10
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2021-12-12
  • 2021-05-14
  • 2021-10-25
  • 2022-12-23
  • 2021-05-20
  • 2022-12-23
  • 2021-09-13
相关资源
相似解决方案