mybatis if test 之 0当做参数传入出问题

2024-09-08 10:18

本文主要是介绍mybatis if test 之 0当做参数传入出问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先前端传入了参数

if(StringUtils.isNotBlank(status)){requestParam.setProperty("status", Integer.parseInt(status));}
List<SuperPojo> applicationList =  groupDao.getApplicationListByReviewStatusAndMember(requestParam);


mapper的sql文为

<select id="getApplicationListByReviewStatusAndMemberCount" parameterType="com.financial.core.pojo.SuperPojo"resultType="Integer" flushCache="true">SELECTcount(1)FROMreview_status rsLEFT JOIN member_info mi ON mi.member_id = rs.member_idLEFT JOIN member m ON rs.member_id = m.member_id<where><if test="name!=null and name!=''">AND mi.name like CONCAT('%',#{name},'%')</if><if test="telephone!=null and telephone!=''">AND mi.telephone = #{telephone}</if><if test="status!=null and status!=''">AND rs.status = #{status}</if><if test="applicationTimeStart!=null and applicationTimeEnd!=null">and rs.update_time >= #{applicationTimeStart} and rs.update_time <DATE_ADD(#{applicationTimeEnd},INTERVAL 1 DAY)</if></where>ORDER BY rs.update_time ASC</select>
解决方法:

mybatis的参数传入为0的时候会把0当做空处理掉

改成如下情况即可

<select id="getApplicationListByReviewStatusAndMemberCount" parameterType="com.financial.core.pojo.SuperPojo"resultType="Integer" flushCache="true">SELECTcount(1)FROMreview_status rsLEFT JOIN member_info mi ON mi.member_id = rs.member_idLEFT JOIN member m ON rs.member_id = m.member_id<where><if test="name!=null and name!=''">AND mi.name like CONCAT('%',#{name},'%')</if><if test="telephone!=null and telephone!=''">AND mi.telephone = #{telephone}</if><if test="status!=null and status!='' or 0 == status">AND rs.status = #{status}</if><if test="applicationTimeStart!=null and applicationTimeEnd!=null">and rs.update_time >= #{applicationTimeStart} and rs.update_time <DATE_ADD(#{applicationTimeEnd},INTERVAL 1 DAY)</if></where>ORDER BY rs.update_time ASC</select>



这篇关于mybatis if test 之 0当做参数传入出问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1147831

相关文章

mybatis映射器配置小结

《mybatis映射器配置小结》本文详解MyBatis映射器配置,重点讲解字段映射的三种解决方案(别名、自动驼峰映射、resultMap),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定... 目录select中字段的映射问题使用SQL语句中的别名功能使用mapUnderscoreToCame

mybatis-plus如何根据任意字段saveOrUpdateBatch

《mybatis-plus如何根据任意字段saveOrUpdateBatch》MyBatisPlussaveOrUpdateBatch默认按主键判断操作类型,若需按其他唯一字段(如agentId、pe... 目录使用场景方法源码方法改造首先在service层定义接口service层接口实现总结使用场景my

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

MyBatis ParameterHandler的具体使用

《MyBatisParameterHandler的具体使用》本文主要介绍了MyBatisParameterHandler的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、概述二、源码1 关键属性2.setParameters3.TypeHandler1.TypeHa

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据