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 

 a.project_id=#{projectId}
 and a.id != #{id}
 and a.status=3 

     
        and a.id_card = #{code}
    
and a.unit_code = #{code}
      
      

登录后复制

解释:

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

以上就是MyBatis动态SQL中,如何避免``和``并列使用导致的BadSql问题?的详细内容,更多请关注慧达安全导航其它相关文章!

点赞(0)

评论列表 共有 0 条评论

暂无评论
立即
投稿
发表
评论
返回
顶部