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

 更新时间:2018年08月08日 11:06:20   作者:饭娱咖啡  
这篇文章主要介绍了Mybatis 中 Oracle 的拼接模糊查询及用法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

一、结论

这里先给大家看一下结论

Oracle 中,拼接模糊查询的正确写法

 SELECT A.USER_ID,
      A.USER_NAME
    FROM USER A
      AND A.USER_NAME like concat(concat('%','w'),'%')
      或者
      AND A.USER_NAME like '%' || 'w' || '%'

Mybatis 中,拼接模糊查询的正确写法

 <select id="selectByName" resultMap="BaseResultMap">
    SELECT A.USER_ID,
      A.USER_NAME
    FROM T_BASE_USER_INFO A
      <if test="userName != null">
        AND A.USER_NAME like '%' || #{userName} || '%'
      </if>
      或者
      <if test="userName != null">
        AND A.USER_NAME like concat(concat('%','${userName}'),'%')
      </if>
  </select>

注意 Mybatis 中,拼接模糊查询的用法

,是将传入的值当做字符串的形式。所以拼接的时候 #{userName} 默认自带引号。例如: ${userName} 直接转为 ‘zhen'。

,是将传入的数据直接显示生成sql语句。所以拼接的时候
,是将传入的数据直接显示生成sql语句。所以拼接的时候
{userName} 没有默认引号。例如:${userName} 直接转为 zhen 。

二、技巧:

刚开始写的时候一直报错,报错信息是这样的:

    "message": "Request processing failed; nested exception is org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.type.TypeException: Could not set parameters for mapping: ParameterMapping{property='userName', mode=IN, javaType=class java.lang.String, jdbcType=null, numericScale=null, resultMapId='null', jdbcTypeName='null', expression='null'}. Cause: org.apache.ibatis.type.TypeException: Error setting non null for parameter #1 with JdbcType null . Try setting a different JdbcType for this parameter or a different configuration property. Cause: java.sql.SQLException: 无效的列索引",

我的写法是这样的:           

 <if test="_parameter != null">
--         AND A.USER_NAME like CONCAT('%','#{userName}','%')
          AND A.USER_NAME = #{userName}
        </if>
<!--        <if test="userType != null">
          AND A.USER_TYPE = #{userType}
        </if>
        <if test="mobilePhoneNo != null">
          AND A.MOBILE_PHONE_NO like CONCAT('%','#{mobilePhoneNo}','%')
        </if>
        <if test="roleId != null">
          AND B.ROLE_ID = #{roleId}
                </if>-->

后来我彻底凌乱了,于是就从头开始写,结果就好了。

小结:

出现的报错可能跟我之前写了太多的if 判断语句有关,于是先写一个简单的          

 <if test="userName != null">
        AND A.USER_NAME like '%' || #{userName} || '%'
      </if>

这个可以执行,其他再有什么条件加进来,稍微修改之后,都可以正常运行。          

 <if test="userName != null">
        AND A.USER_NAME like concat(concat('%','${userName}'),'%')
      </if>
      <if test="userType != null">
        AND A.USER_TYPE = #{userType}
      </if>
      <if test="mobilePhoneNo != null">
        AND A.MOBILE_PHONE_NO like '%' || #{mobilePhoneNo} || '%'
      </if>
      <if test="baseRoleInfo.roleId != null">
        AND B.ROLE_ID = #{baseRoleInfo.roleId}
      </if>

总结

以上所述是小编给大家介绍的Mybatis 中 Oracle 的拼接模糊查询,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • SpringBoot详解MySQL如何实现读写分离

    SpringBoot详解MySQL如何实现读写分离

    当响应的瓶颈在数据库的时候,就要考虑数据库的读写分离,当然还可以分库分表,那是单表数据量特别大,当单表数据量不是特别大,但是请求量比较大的时候,就要考虑读写分离了.具体的话,还是要看自己的业务...如果还是很慢,那就要分库分表了...我们这篇就简单讲一下读写分离
    2022-09-09
  • Java Spring-Cache key配置注意事项介绍

    Java Spring-Cache key配置注意事项介绍

    本文主要对java spring-cache key配置注意事项进行了介绍,小编觉得还是挺不错的,这里分享给大家,供需要的朋友参考。
    2017-10-10
  • Spring boot项目部署到云服务器小白教程详解

    Spring boot项目部署到云服务器小白教程详解

    这篇文章主要介绍了Spring boot项目部署到云服务器小白教程详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • idea 实现纵列选择和大小写转换操作

    idea 实现纵列选择和大小写转换操作

    这篇文章主要介绍了idea 实现纵列选择和大小写转换操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • Java中的日期和时间类以及Calendar类用法详解

    Java中的日期和时间类以及Calendar类用法详解

    这篇文章主要介绍了Java中的日期和时间类以及Calendar类用法详解,是Java入门学习中的基础知识,需要的朋友可以参考下
    2015-09-09
  • Java Stream中的Spliterator类概念及原理解析

    Java Stream中的Spliterator类概念及原理解析

    Spliterator是Java 8引入的一个接口,位于java.util包中,它结合了迭代器(Iterator)的遍历能力和分割器(Splitter)的分割能力,本文将详细介绍Spliterator的概念、原理、作用、类中定义的关键方法,以及它在Stream API中的实际应用,感兴趣的朋友一起看看吧
    2024-08-08
  • java微信红包实现算法

    java微信红包实现算法

    这篇文章主要为大家详细介绍了java微信红包实现算法,列出红包的核心算法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02
  • Java下载安装和环境变量配置图文教程

    Java下载安装和环境变量配置图文教程

    这篇文章主要为大家详细介绍了Java下载安装和环境变量配置图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-10-10
  • macOS中搭建Java8开发环境(基于Intel x86 64-bit)

    macOS中搭建Java8开发环境(基于Intel x86 64-bit)

    这篇文章主要介绍了macOS中搭建Java8开发环境(基于Intel x86 64-bit) 的相关资料,需要的朋友可以参考下
    2022-12-12
  • SpringMVC实现用户登录全过程

    SpringMVC实现用户登录全过程

    这篇文章主要介绍了SpringMVC实现用户登录全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-09-09

最新评论