概述
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}是过滤列名
以上为个人经验,希望能给大家一个参考,也希望大家多多支持靠谱客。
最后
以上就是生动皮卡丘为你收集整理的mybatis的映射xml中动态设置orderby方式的全部内容,希望文章能够帮你解决mybatis的映射xml中动态设置orderby方式所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复