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 的拼接模糊查询,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
相关文章
如何解决Project SDK is not defined问题
这篇文章主要介绍了如何解决Project SDK is not defined问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2023-09-09详解Spring boot Admin 使用eureka监控服务
本篇文章主要介绍了详解Spring boot Admin 使用eureka监控服务,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2017-12-12在CentOS7(有图形化界面)上安装maven和idea的详细教程
这篇文章主要介绍了在CentOS7(有图形化界面)上安装maven和idea的详细教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-03-03Maven是什么?Maven的概念+作用+仓库的介绍+常用命令的详解
Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑.,本文给大家介绍Maven的概念+作用+仓库的介绍+常用命令,感兴趣的的朋友跟随小编一起看看吧2020-09-09SpringBoot整合定时任务之实现Scheduled注解的过程(一个注解全解决)
这篇文章主要介绍了SpringBoot整合定时任务之实现Scheduled注解的过程(一个注解全解决),本文通过使用场景分析给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-09-09
最新评论