大家好,我只是IT行业的一只菜鸟,最近做的项目要求用Mybatis技术,在做一个模糊查询的时候,遇到点麻烦,经过1天的研究,反复尝试,终于找到问题所在,借此机会与大家分享一下,谢谢!
Mybatis配置如下:
<select id="getAll" resultMap="OaEmplyeeInfoResultMap"
parameterType="com.deppon.oa.module.oaEmplyeeInfo.domain.OaEmplyeeInfo">
<![CDATA[
SELECT
]]>
<include refid="select_param" />
<![CDATA[
FROM OM_EMPLOYEE
]]>
<where>
<if test="empcode!=null">
AND EMPCODE = #{empcode}
</if>
<if test="empname!=null">
AND EMPNAME LIKE #{empname}
</if>
</where>
</select>
Dao层如下:
public List<OaEmplyeeInfo> getAllByName(OaEmplyeeInfo oaEmplyeeInfo,String empname){
List<OaEmplyeeInfo> list=null;
Map map=new HashMap();
map.put("empname", empname);
list=(List<OaEmplyeeInfo>) getSqlSession().selectList("com.deppon.oa.module.oaEmplyeeInfo.domain.OaEmplyeeInfo.getAll", map);
return list;
}
测试代码如下:
public void testQuery(){
List<OaEmplyeeInfo> fos=null;
fos = oaEmplyeeInfoDao.getAllByName(null,"王");
for(OaEmplyeeInfo li:fos){
System.out.println(li.getEmpname());
}
Assert.assertNotNull(fos.get(0).getCardno());
}
发现怎么都查不出来数据,最后查询资料才得知:
原来Mybatis用like进行模糊查询的时候,配置与所用的数据库有关系,总结了下,具体如下:
1、mysql :LIKE CONCAT('%',#{empname},'%' ) 或者 LIKE CONCAT('%',‘${empname}’,'%' )
2、oracle:LIKE '%'||#{empname}||'%'
我用的是oracle 把配置文件改为:
<select id="getAll" resultMap="OaEmplyeeInfoResultMap"
parameterType="com.deppon.oa.module.oaEmplyeeInfo.domain.OaEmplyeeInfo">
<![CDATA[
SELECT
]]>
<include refid="select_param" />
<![CDATA[
FROM OM_EMPLOYEE
]]>
<where>
<if test="empcode!=null">
AND EMPCODE = #{empcode}
</if>
<if test="empname!=null">
AND EMPNAME LIKE '%'||#{empname}||'%'
</if>
</where>
</select>
运行测试,查询OK
分享到:
相关推荐
特殊字符(\,_,%)转义工具类 MyQueryInterceptor.java: Mybatis自定义拦截器 注意:该拦截器只支持QueryWrapper的like方法,serviceImpl层传全角模糊查询(%%) mapper或xml层的全角模糊查询(%*%)和半角模糊查询(%*或*%)
主要介绍了Mybatis中的like模糊查询功能,非常不错,具有参考借鉴价值,需要的朋友可以参考下
mybatis的逆向助手确实好用,可以省去很多编写常规sql语句的时间,但是它没办法自动生成模糊查询语句,但开发中模糊查询是必不可少的,所以,需要手动对mapper编写模糊查询功能。 这里先明确MyBatis/Ibatis中#和$的...
MyBatis模糊查询
主要介绍了Mybatis 中 Oracle 的拼接模糊查询及用法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
代码包含: EscapeUtil.java:特殊字符(\,_,%)转义工具类 MyQueryInterceptor.java: Mybatis自定义拦截器 注意:该拦截器只支持QueryWrapper的like方法,serviceImpl层传全角模糊查询(%%) mapper或xml层的全角模糊查询(%...
mybatis模糊查询,oracal,mysql,sqlserver三种不同数据库的不同写法
主要介绍了MyBatis实现模糊查询的几种方式,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
Mybatis框架(子查询)
主要介绍了MyBatis-plus 模糊查询的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
使用Mybatis框架的模糊查询,详细博客地址:https://blog.csdn.net/qq_36654606/article/details/87393383
主要介绍了MyBatis中的模糊查询语句的相关资料,需要的朋友可以参考下
模糊查询也是数据库SQL中使用频率很高的SQL语句,这篇文章主要介绍了详解MyBatis模糊查询LIKE的三种方式,非常具有实用价值,需要的朋友可以参考下
ojdbc6(此包解决mybatis_plus查询时分秒为0问题),springboot项目+oracle11g就用这个jdbc就行,放在项目的resources目录下lib目录下就行,然后配置下pom文件即可 <!-- maven oracle依赖包 --> <groupId>jcca ...
针对父子级数据目录查询, 以前都是逐级的去根据父级id查询子集目录, 查出后最后再在代码中拼成树形结构, 相当复杂,我们可以利用 mybatis 提供的 collection 标签自动组织树形结构
主要介绍了MyBatis之自查询使用递归实现 N级联动效果,本文给大家分享两种实现方式,需要的的朋友参考下吧
mybatis多条件查询处理方案(查询条件为数据库字段非传递参数)
mybatis多表查询.zip
主要介绍了利用MyBatis进行不同条件的like模糊查询,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
这是一个springboot架构搭建的一个整合mybatis递归查询的demo,其中整合了分布式事物jta,mybatis的分页插件等