关于mybatis模糊查询的问题,求大神帮忙看下
下面这个是用xml配置实现的模糊查询,没有问题。<selectid="findByLike"parameterType="string"resultType="User"...
下面这个是用xml配置实现的模糊查询,没有问题。
<select id="findByLike" parameterType="string" resultType="User">
select * from t_user where 1 = 1
<if test="_parameter != null">
and username like "%"#{username}"%";
</if>
</select>
之后,我想把它改成用注解实现,
@Select("select * from t_user where 1 = 1 "
+ "and username like #{keyword};")
public List<User> findByLike(@Param("keyword")String keyword) throws Exception;
我不知道那个“%”,加在哪个位置上,试了很多种,都不行,求大神帮忙看下 展开
<select id="findByLike" parameterType="string" resultType="User">
select * from t_user where 1 = 1
<if test="_parameter != null">
and username like "%"#{username}"%";
</if>
</select>
之后,我想把它改成用注解实现,
@Select("select * from t_user where 1 = 1 "
+ "and username like #{keyword};")
public List<User> findByLike(@Param("keyword")String keyword) throws Exception;
我不知道那个“%”,加在哪个位置上,试了很多种,都不行,求大神帮忙看下 展开
2个回答
展开全部
使用函数CONCAT(str1,str2,…)
username like CONCAT('%',#{username},'%')
username like CONCAT('%',#{username},'%')
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2014-01-07
展开全部
看看生成的SQL是如何的
另外,
+ "and username like #{keyword};")
里面不要加;号
另外,
+ "and username like #{keyword};")
里面不要加;号
追问
加上分号,没有问题。比如:keyword=“a”,生成的sql语句就是这样:select * from t_user where 1 = 1 and username like 'a';
我想要的是like '%a%',不知道怎么改?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询