mybatis传入参数为0被误认为是空字符串的解决方法
在mbatis中使用Xml配置sql语句时,出现了这样一个问题。当我传入的参数为0去做判断时,mybatis会把参数0当成是空字符串去判断而引起查询结果错误
所以在做项目时一定要注意,用到MyBatis时,避免用0来做值。
下面是我的解决办法
<if test="gender != null and (gender !='' or gender == 0) ">
    AND gender = #{gender}
</if>
在后面街上or == 0的判断就可以了
mybatis传入参数为0被误认为是空字符串的解决方法的更多相关文章
- Mybatis的if标签判断空字符串 == 0,参数为0时会自动转为空字符串
		
对于这个问题,有两种解决办法. 1.当传入的参数有0时,只判断!=null即可. 2.将0转化为String类型,就可以解决这个问题.
 - MyBatis传入参数为list、数组、map写法(转载)
		
MyBatis传入参数为list.数组.map写法 1.foreach简单介绍: foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合. foreach元素的属性主要有item ...
 - MyBatis传入参数为list、数组、map写法
		
1.foreach简单介绍: foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合. foreach元素的属性主要有item,index,collection,open,sep ...
 - 错误:Unsupported major.minor version 51.0(jdk版本错误)的解决方法
		
错误:Unsupported major.minor version 51.0(jdk版本错误)的解决方法 java.lang.UnsupportedClassVersionError: org/ap ...
 - IIS6.0 IIS7.5应用程序池自动停止的解决方法 搜集整理
		
来源:http://www.guchengnet.com/1499.html IIS6.0 IIS7.5应用程序池自动停止的解决方法 搜集整理 发表于2016年12月14日 有2.3个月没有用本地的i ...
 - localhost不能访问127.0.0.1可以访问的原因及解决方法    被打磨的不像人样
		
localhost不能访问127.0.0.1可以访问的原因及解决方法 作者:admin 时间:2013-12-16 10:58:47 浏览:16599 有时候我们在调试程序的时候,会出 ...
 - @JsonInclude(Include.NON_NULL) resttemplate 传递实体参数时 序列化为json时 空字符串不参与序列化
		
@JsonInclude(Include.NON_NULL) resttemplate 传递实体参数时 序列化为json时 空字符串不参与序列化 https://www.cnblogs.com/sup ...
 - MyBatis传入参数为集合、数组SQL写法
		
参考:http://blog.csdn.net/small____fish/article/details/8029030 foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合 ...
 - MyBatis传入参数与parameterType
		
参考:http://openwares.net/database/mybatis_parametertype.html Mybatis的Mapper文件中的select.insert.update.d ...
 
随机推荐
- SpringBoot整合Shiro实现权限控制
			
目录 1.SpringBoot整合Shiro 1.1.shiro简介 1.2.代码的具体实现 1.2.1.Maven的配置 1.2.2.整合需要实现的类 1.2.3.项目结构 1.2.4.ShiroC ...
 - MongoDB 基础学习
			
1.MongoDB 概念解析 SQL术语/概念 MongoDB术语/概念 解释/说明 database database 数据库 table collection 数据库表/集合 row docume ...
 - React组件三大属性之 refs
			
React组件三大属性之 refs refs属性 1) 组件内的标签都可以定义ref属性来标识自己 a. <input type="text" ref={input => ...
 - Ubuntu 18.04 开启 root 账号并允许远程连接
			
转载:https://blog.csdn.net/u010766726/article/details/105376461 以普通用户登录系统 通过 "终端" 操作 普通用户 – ...
 - informix常见问题
			
1.中文乱码 https://www.cnblogs.com/equation/p/5545967.html 2.informix创建数据库和用户 https://wenku.baidu.com/vi ...
 - C#曲线分析平台的制作(四,highcharts+ajax加载后台数据)
			
在上一篇博客:C#曲线分析平台的制作(三,三层构架+echarts显示)中已经完成了后台的三层构架的简单搭建,为实现后面的拓展应用开发和review 改写提供了方便.而在曲线分析平台中,往往有要求时间 ...
 - mysql 占用90%多的CPU,解决思路
			
网站打开很慢,爆出了连接数据库的错误,进入服务器,top 看了下,mysql占用cpu 基本维持在90以上: mysql> show variables like '%slow%'; ...
 - jquery 判断单/复选框是否被选中
			
1 <div> 2 <span>高亮:</span><input type="checkbox" name="light&quo ...
 - DC-2 靶机渗透测试
			
DC-2 靶机渗透测试 冲冲冲,好好学习. 本靶机核心内容"受限shell提权",知识点在另一篇文章中总结归纳了. 攻击机:kali 靶 机:DC-2 准备:在使用前需要在操作机的 ...
 - 关于C语言中的unsigned
			
在C语言中,对unsigned做出(unsigned int)i>=0 判断,将会得到一个永真值. int i; for(i=10;i-sizeof(int)>=0;i--){ print ...