`

Mybatis like 模糊查询问题

阅读更多

       大家好,我只是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

 

 

1
4
分享到:
评论
1 楼 PeTiRo 2012-10-18  
AND EMPNAME LIKE '%${empname}%'
#->$
试试这样\

相关推荐

    Mybatis中的like模糊查询功能

    在Mybatis这个流行的持久层框架中,实现模糊查询功能,特别是`LIKE`操作,可以帮助开发者更灵活地处理数据过滤。本文将详细介绍Mybatis中使用`LIKE`进行模糊查询的几种方法。 1. **参数中直接加入`%`** 在Mybatis...

    MyBatis模糊查询

    ### MyBatis模糊查询知识点详解 ...通过上述介绍,我们不仅了解了MyBatis模糊查询的基本概念和实现方法,还学习了一些最佳实践和潜在的安全问题。这对于提高MyBatis应用程序的灵活性和安全性具有重要意义。

    Mybatis自定义拦截器,对模糊查询传值的特殊字符统一进行转义处理的代码

    特殊字符(\,_,%)转义工具类 MyQueryInterceptor.java: Mybatis自定义拦截器 注意:该拦截器只支持QueryWrapper的like方法,serviceImpl层传全角模糊查询(%%) mapper或xml层的全角模糊查询(%*%)和半角模糊查询(%*或*%)

    利用MyBatis进行不同条件的like模糊查询的方法

    MyBatis like模糊查询方法 MyBatis是一个流行的持久层框架,提供了强大的查询功能。其中,like模糊查询是最常用的查询方式之一。本文将介绍如何使用MyBatis进行不同条件的like模糊查询。 like模糊查询的原理 like...

    使用Mybatis框架的模糊查询

    本文将深入探讨如何在Mybatis框架中实现模糊查询,以帮助开发者更高效地进行数据检索。 首先,理解模糊查询的基本概念。在SQL中,模糊查询通常使用`LIKE`关键字来实现,允许我们在条件表达式中包含通配符,以匹配...

    mybatis 模糊查询的实现方法

    在MyBatis中,模糊查询是一种常见的查询方式,特别是在数据搜索功能中不可或缺。本文将详细介绍如何在MyBatis中实现模糊查询,以及`#`和`$`的区别。 首先,让我们来理解`#`和`$`的区别。这两个符号在MyBatis中用于...

    Mybatis 中 Oracle 的拼接模糊查询及用法详解

    Mybatis 中 Oracle 的拼接模糊查询及用法详解 Mybatis 是一个基于 Java 的持久层框架,提供了强大的数据库交互能力,而 Oracle 则是业界最流行的关系数据库管理系统。本文将详细介绍 Mybatis 中 Oracle 的拼接模糊...

    MyBatis实现模糊查询的几种方式

    MyBatis实现模糊查询的几种方式 MyBatis是一款流行的基于Java的持久层框架,它提供了强大灵活的方式来与数据库进行交互。在实际开发中,我们经常需要实现模糊查询来满足业务需求。今天,我们将探讨MyBatis实现模糊...

    MyBatis中的模糊查询语句

    MyBatis的模糊查询不仅限于简单的`LIKE`操作,还可以结合其他SQL函数,如`SUBSTRING`、`INSTR`等,实现更复杂的模糊匹配逻辑。同时,MyBatis的动态SQL特性使得我们可以根据不同的业务需求灵活构造查询语句。 总的来...

    MyBatis-plus 模糊查询的使用

    MyBatis-plus提供了简单易用的模糊查询功能。 在MyBatis-plus中,模糊查询主要通过`QueryWrapper`类来实现。`QueryWrapper`是一个条件构造器,可以方便地构建复杂的查询条件。以下是如何使用`QueryWrapper`进行模糊...

    Mybatis自定义拦截器,对模糊查询传值的特殊字符(\,_,%)统一进行转义处理的代码

    代码包含: EscapeUtil.java:特殊字符(\,_,%)转义工具类 MyQueryInterceptor.java: Mybatis自定义拦截器 注意:该拦截器只支持QueryWrapper的like方法,serviceImpl层传全角模糊查询(%%) mapper或xml层的全角模糊查询(%...

    mybatis like传值

    在MyBatis框架中处理SQL查询时,经常需要根据用户输入的模糊查询条件来构建动态SQL语句。其中,“LIKE”语句是实现这一功能的重要手段之一。本文将针对提供的四种不同的MyBatis LIKE传值方式展开详细分析,并探讨每...

    mybatis 增删改查 模糊查询 操作

    在本教程中,我们将深入探讨如何在 MyBatis 中进行基本的 CRUD(创建、读取、更新、删除)操作以及模糊查询。 1. **创建(Create)**: 创建操作通常涉及插入新记录到数据库。在 MyBatis 中,你可以通过 XML 映射...

    mybatis分页及模糊查询功能实现

    MyBatis分页及模糊查询功能实现 MyBatis是一款流行的持久层框架,它提供了强大的数据库交互能力,包括分页和模糊查询功能。在实际开发中,分页和模糊查询是最常用的功能,下面我们将详细介绍MyBatis如何实现分页和...

    Mybatis模糊查询和动态sql语句的用法

    在Mybatis中,我们可以使用LIKE关键字来实现模糊查询。例如: ```sql SELECT * FROM oa_employee WHERE emp_name LIKE #{asd} ``` 但是,这种方法存在问题,因为没有实现真正的模糊查询。如果我们想实现真正...

    浅谈MySQL模糊查询中通配符的转义

    sql中经常用like进行模糊查询,而模糊查询就要用到百分号“%”,下划线“_”这些通配符,其中“%”匹配任意多个字符,“_”匹配单个字符。如果我们想要模糊查询带有通配符的字符串,如“60%”,“user_name”,就...

    springMvc+mybatis 招聘网站 模糊查询 登录验证完整项目

    对于模糊查询功能,Mybatis允许我们编写灵活的SQL,如使用LIKE操作符配合通配符%,实现关键词的模糊匹配。同时,Mybatis的动态SQL功能使得可以根据不同的条件动态生成查询语句,提高了代码的可复用性和灵活性。 在...

    MyBatis实现动态查询、模糊查询功能

    MyBatis实现动态查询、模糊查询功能 MyBatis是一款非常流行的ORM框架,它提供了强大的数据库交互功能,今天我们就来学习如何使用MyBatis实现动态查询和模糊查询功能。 动态查询 动态查询是指根据不同的条件生成...

    MyBatis-Plus之分页模糊查询

    在进行模糊查询时,我们可以使用`like`操作符配合`%`通配符来实现。例如,如果我们要查找用户名包含"张"的所有用户,可以使用`userMapper.selectByUserNameLike("%张%")`,其中`selectByUserNameLike`是自定义的方法...

Global site tag (gtag.js) - Google Analytics