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);
分享数据库前沿,解构实战干货,推动数据库技术变革