java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > mybatis映射xml动态设置orderby

mybatis的映射xml中动态设置orderby方式

作者:左直拳

这篇文章主要介绍了mybatis的映射xml中动态设置orderby方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

mybatis映射xml动态设置orderby

mybatis的dao xml中,根据参数值设置不同的order by字段。

dao java

List<DzRainDetail> queryDetail(@Param("masterId") int masterId, 
@Param("country") String country, 
@Param("sort") String sort);

第三个参数“sort”用于决定如何写这个order by。

dao XML

<select id="queryDetail" resultMap="DetailResultMap">
    SELECT rd.id, st.address, rd.water, st.d_name
    FROM dzzhyj.dz_rain_detail rd
    INNER JOIN dzzhyj.DZ_RAIN_STATION st ON rd.station_code = st.code
    WHERE rd.master_id = #{masterId}
    AND st.country = #{country}
    <if test="sort.compareTo('d') == 0">
        ORDER BY st.d_name ASC
    </if>
    <if test="sort.compareTo('water') == 0">
        ORDER BY rd.water DESC
    </if>
</select>

由于sort是字符串,String类型,我发现写成以下形式会报错:

<if test="sort == 'd'">
    ORDER BY st.d_name ASC
</if>
<if test="sort == 'water'">
    ORDER BY rd.water DESC
</if>

系统会将sort认为是数值型,抛出异常说无法识别的值。

mybatis动态传入order by参数的正确方式

正确方式:

ORDER BY #{shop_id} 换成 ORDER BY ${shop_id}

备注: #{shop_id}是过滤列值, ¥{shop_id}是过滤列名

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文