MyBatis动态SQL中,如何避免“和“并列使用导致的BadSql问题?

MyBatis动态SQL中,如何避免“和“并列使用导致的BadSql问题?

mybatis动态sql导致badsql问题

使用mybatis的动态sql条件判断时,需要使用标签来包裹不同的条件判断。

错误示例:

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}

原因:
标签内,条件并列使用时,会产生语义错误。

优化后的代码:

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>

解释:

优化后的代码使用标签对不同的条件进行判断,确保只有满足条件的分支才会被执行,从而解决了badsql问题。

© 版权声明
THE END
喜欢就支持一下吧
点赞10 分享