mybatis中如果希望sql语句根据传入的参数取值变化,应该怎么处理?
< if test="usrName != null and userName != ''">
and user_name concat('%',#{userName}, '%')
< /if>
需要的是这个?
可以通过#{xxxx}
或者${xxxx}
设置变量
#{xxx}
会自动做escape${xxx}
只是字符串替换,有sql注入风险
可以参考官方文档 http://www.mybatis.org/mybatis-3/dynamic-sql.html
例子(mybatis的xml方式)
<select id="selectOneById" resultType="Object">
select id from test_table where id = #{id}
</select>
例子(mybatis的标注方式):
@Select({
"select id "
"from test_table where id = #{id}"
})
Object selectOneById(@Param("id") long id);
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。