
mybatis动态sql导致badsql问题
使用mybatis的动态sql条件判断时,需要使用<choose> <when> <otherwise>标签来包裹不同的条件判断。
错误示例:
select * from table a where a.project_id=#{projectid} and a.id != #{id} and a.status=3 and a.id_card = #{code} or a.unit_code = #{code}原因:
在<where>标签内,<condition>和<or>条件并列使用时,会产生语义错误。
优化后的代码:
select * from table a
<where>
a.project_id=#{projectId}
and a.id != #{id}
and a.status=3
<choose>
<when test="type == idCard">
and a.id_card = #{code}
</when>
<when test="type == unitCode">and a.unit_code = #{code}</when>
<otherwise>
</otherwise>
</choose>
</where>解释:
优化后的代码使用<choose> <when> <otherwise>标签对不同的条件进行判断,确保只有满足条件的分支才会被执行,从而解决了badsql问题。
以上就是MyBatis动态SQL中,如何避免``和``并列使用导致的BadSql问题?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号