时间:2021-05-20
今日遇到的问题:
查询版本信息时,由于version是Integer类型,所以当前台选择版本为0时,变成了查询了所有的版本信息。
sql片段:
</if><if test="version != null and version != '' "> AND a.version = #{version} </if>原因:
MyBatis因自身原因默认了 Integer类型数据值等于0时 为 ""(空字符串)
解决办法:
1. 某些情况下,可以在Controller处就拦截,并向前台提示,比如:“必须输入有效数字”,不让他再往后传。
2. 将判断条件version != ''删去,不让它判断。
如:
</if><if test="version != null ">AND a.version = #{version}</if>弊端:就是当有哪位仁兄真的用这个方法传了个空字符串,就无法判断。
3. 单独加上当version为0的特殊情况
如:
</if><if test="version != null and version != '' or version ==0 ">AND a.version = #{version}</if>当然,如果想默认输入为0时查询所有(类似于上述问题示例)或者是后面想转为空字符串,
可以不用改,也算是巧用"bug"。
以上就是本次介绍的全部知识点内容,感谢大家对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
vb中integer是用来声明变量的类型是数字类型,Integer变量存储为16位(2个字节)的数值形式,其范围为-32768到32767之间。 Visual
Mybatis的mapper.xml中update语句使用if标签判断对像属性是否为空值。UserDTO是传过来参数的类型,userDTO是在mapperDao
sql2005若字段定义的类型为datetime,插入为''(空),那么会默认值为1900-01-0100:00:00.000解决方法查询的时候过滤下cast(
一、先说说int与integer的区别 int是基本数据类型,默认值为0,不需要进行实例化 integer是引用数据类型,是int的封装类型,默认值为nul
字段类型为tinyint(1)的返回类型设置为integer现象描述:数据库表字段类型为:tinyint长度为1,即类型为:tinyint(1)查询时,该字段对