方法1:在其它地方对其进行相关处理,语句与正常的查询无异
在sqlMap中与正常的无异,如下所示:
<select id="getNovaUserInfoByNickLike" resultMap="novaUserInfoMap">
<include refid="selectNovaUserInfoAll"/>
where
nick like #{nick} order by createdAt desc
</select>
public List<NovaUserInfo> getNovaUserInfoByNickLike(@Param(value = "nick")String nick);
在Dao的接口中与正常查询无异:
public List<NovaUserInfo> getNovaUserInfoByNickLike(String nick);
在Dao的实现中要做一些简单的操作:
@Override
public List<NovaUserInfo> getNovaUserInfoByNickLike(String nick,PageQuery pageQuery) {
return this.novaUserInfoMapper.getNovaUserInfoByNickLike("%"+nick+"%");
}
ibatis中配置模糊查询:
<select id="getNovaUserInfoByNickLike" resultMap="novaUserInfoMap">
<include refid="selectNovaUserInfoAll"/>
where
nick like '%$sname$%' order by createdAt desc
</select>
select sname,sid from student where sname like '%$sname$%';
方法2:直接在sql语句中写,其它的不变
第一种方法
<select id="selectPersons" resultType="person" parameterType="person">
<bind name="pattern" value="'%' + _parameter.username + '%'" />
select id,sex,age,username,password
from person
where username LIKE #{pattern}
</select>
第二种方法
<select id="getNovaUserInfoByNickLike" resultMap="novaUserInfoMap">
<include refid="selectNovaUserInfoAll"/>
where
nick like CONCAT('%',' #{nick}','%' ) order by createdAt desc
</select>