服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|JavaScript|易语言|

服务器之家 - 编程语言 - Java教程 - 解决mybatis where-if中if不能识别大写AND,OR的问题

解决mybatis where-if中if不能识别大写AND,OR的问题

2021-08-03 10:05↘"LYong Java教程

这篇文章主要介绍了解决mybatis where-if中if不能识别大写AND,OR的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

mybatis报错:

?
1
caused by: org.apache.ibatis.ognl.parseexception: encountered " "and “” at line 1

错误代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
<select id="selectaccountlist" resultmap="baseresultmap">
  select ct.customer_name customername,sam.city_code,sam.user_name,sam.account_name
 from sys_account_manager sam left join sys_customer ct on ct.id = sam.customer_id
  where sam.deleted = 0
  <if test="customername != null and customername != '' ">
  and ct.customer_name like concat('%',#{customername},'%')
  </if>
  <if test="citycode != null and citycode != '' ">
  and locate(#{citycode},sam.city_code)
  </if>
  order by status,account_validity_time desc
 </select>

正确代码:

原因是:

if条件中and为大写,大写不能识别,应改为小写。

?
1
2
3
4
5
6
7
8
9
10
11
12
<select id="selectaccountlist" resultmap="baseresultmap">
  select ct.customer_name customername,sam.city_code,sam.user_name,sam.account_name
 from sys_account_manager sam left join sys_customer ct on ct.id = sam.customer_id
  where sam.deleted = 0
  <if test="customername != null and customername != '' ">
  and ct.customer_name like concat('%',#{customername},'%')
  </if>
  <if test="citycode != null and citycode != '' ">
  and locate(#{citycode},sam.city_code)
  </if>
  order by status,account_validity_time desc
 </select>

补充:mybatis中if判断遇到的坑

最近在项目开发的过程中,遇到了mybatis的一个坑(也许是mybatis有意这样设计的),对于integer或者long这种引用数据类型,在做if判断的时候,如果引用数据类型为0,则mybatis将会视为”“空字符串,所以走不进判断逻辑里。

以下余额字段为long类型,availableamount值为0时,将走不进判断方法内的示例截图:

解决mybatis where-if中if不能识别大写AND,OR的问题

解决方法:

在test判断条件中添加”or availableamount==0“即可,以下是示例截图:

解决mybatis where-if中if不能识别大写AND,OR的问题

或者在业务场景允许的情况下,只判断availableamount!=null

?
1
2
3
<if test="availableamount!=null">
  ...
</if>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。如有错误或未考虑完全的地方,望不吝赐教。

原文链接:https://blog.csdn.net/weixin_39093006/article/details/91041819

延伸 · 阅读

精彩推荐
  • Java教程详解java中的byte类型

    详解java中的byte类型

    Java也提供了一个byte数据类型,并且是基本类型。java byte是做为最小的数字来处理的,因此它的值域被定义为-128~127,也就是signed byte。下面这篇文章主要给...

    夜有所思,日有所梦5522020-08-18
  • Java教程解析Java中的Field类和Method类

    解析Java中的Field类和Method类

    这篇文章主要介绍了Java中的Field类和Method类,是Java入门学习中的基础知识,需要的朋友可以参考下 ...

    爪哇小博5372020-03-19
  • Java教程Java指定保留小数位数的方法

    Java指定保留小数位数的方法

    本篇文章主要介绍了Java指定保留小数位数的方法,很多时候需要规定保留的小数位数,这里整理了详细的代码,有需要的小伙伴可以参考下。 ...

    CodingSean1722020-08-27
  • Java教程ant使用指南详细入门教程

    ant使用指南详细入门教程

    这篇文章主要介绍了ant使用指南详细入门教程,本文详细的讲解了安装、验证安装、使用方法、使用实例、ant命令等内容,需要的朋友可以参考下 ...

    junjie2242019-12-20
  • Java教程Kotlin基础教程之数据类型

    Kotlin基础教程之数据类型

    这篇文章主要介绍了Kotlin基础教程之数据类型的相关资料,需要的朋友可以参考下 ...

    天命剑主4322020-11-01
  • Java教程使用java执行定时任务示例

    使用java执行定时任务示例

    这篇文章主要介绍了使用java执行定时任务示例,需要的朋友可以参考下 ...

    java教程网4982019-11-17
  • Java教程jedispool连redis高并发卡死的问题

    jedispool连redis高并发卡死的问题

    本篇文章主要介绍了jedispool连redis高并发卡死的问题,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    五只鸭子8282021-04-13
  • Java教程java单链表逆序用法代码示例

    java单链表逆序用法代码示例

    这篇文章主要介绍了java单链表逆序用法代码示例,小编觉得还是挺不错的,具有一定借鉴价值,需要的朋友可以参考下...

    Marksinoberg4532021-03-27