Python 官方文档:入门教程 => 点击学习
目录mybatis映射xml动态设置orderbymybatis动态传入order by参数的正确方式mybatis映射xml动态设置orderby mybatis的dao xml中
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认为是数值型,抛出异常说无法识别的值。
正确方式:
ORDER BY #{shop_id} 换成 ORDER BY ${shop_id}
备注: #{shop_id}是过滤列值, ¥{shop_id}是过滤列名
以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。
--结束END--
本文标题: mybatis的映射xml中动态设置orderby方式
本文链接: https://www.lsjlt.com/news/158790.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0