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


SELECTA.USER_ID,
A.USER_NAME
FROMT_BASE_USER_INFOA

ANDA.USER_NAMElike'%'||#{userName}||'%'

或者

ANDA.USER_NAMElikeconcat(concat('%','${userName}'),'%')

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

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

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

二、技巧:

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

"message":"Requestprocessingfailed;nestedexceptionisorg.mybatis.spring.MyBatisSystemException:nestedexceptionisorg.apache.ibatis.type.TypeException:Couldnotsetparametersformapping:ParameterMapping{property='userName',mode=IN,javaType=classjava.lang.String,jdbcType=null,numericScale=null,resultMapId='null',jdbcTypeName='null',expression='null'}.Cause:org.apache.ibatis.type.TypeException:Errorsettingnonnullforparameter#1withJdbcTypenull.TrysettingadifferentJdbcTypeforthisparameteroradifferentconfigurationproperty.Cause:java.sql.SQLException:无效的列索引",

我的写法是这样的:


--ANDA.USER_NAMElikeCONCAT('%','#{userName}','%')
ANDA.USER_NAME=#{userName}

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

小结:

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


ANDA.USER_NAMElike'%'||#{userName}||'%'

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


ANDA.USER_NAMElikeconcat(concat('%','${userName}'),'%')


ANDA.USER_TYPE=#{userType}


ANDA.MOBILE_PHONE_NOlike'%'||#{mobilePhoneNo}||'%'


ANDB.ROLE_ID=#{baseRoleInfo.roleId}

总结

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

热门推荐

1 虎年新年专属祝福语简短
2 恋爱很久的祝福语简短
3 单位搬迁新楼祝福语简短
4 新年祝福语给婆婆简短
5 简短媳妇的生日祝福语
6 相恋人回去祝福语简短
7 新人给朋友祝福语简短
8 结婚给姐妹祝福语简短
9 结婚对白誓言简短祝福语
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短