关于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;
我不知道那个“%”,加在哪个位置上,试了很多种,都不行,求大神帮忙看下
展开
 我来答
百度网友58fd71151
2014-01-07 · TA获得超过391个赞
知道小有建树答主
回答量:442
采纳率:100%
帮助的人:138万
展开全部
使用函数CONCAT(str1,str2,…)

username like CONCAT('%',#{username},'%')
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2014-01-07
展开全部
看看生成的SQL是如何的

另外,
+ "and username like #{keyword};")

里面不要加;号
追问
加上分号,没有问题。比如:keyword=“a”,生成的sql语句就是这样:select * from t_user where 1 = 1 and username like 'a';
我想要的是like '%a%',不知道怎么改?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式