mybatis的if判断⽤法
mybatis的if判断语句其实跟el表达式的if条件判断有些类似。
例如:
1 如果参数为数字类型的时候没有特俗需求的情况只需要判断是否为null即可。
例如:
如果有特俗需求,例如判断是否⼤于某个数的时候才⾏。只需要加上对应的条件判断即可
例如:
mybatis对于这种⼤于⼩于等等还有另⼀种形式。
例如:
对应关系:
gt 对应 >
gte 对应 >=
lt 对应 <(会报错相关联的 "test" 属性值不能包含 '<' 字符)
lte 对应 <=(会报错相关联的 "test" 属性值不能包含 '<' 字符)
2 如果为字符串类型
2.1 如果不需要过滤空串的情况 仅仅判断null即可
例如:
2.2 如果需要过滤空串,添加空串判断即可 不⽀持 && 所以这⾥⽤ and or || 来做逻辑与或的判断例如: 或者
2.3 如果判断字符串是否已某个特俗字符开头,结尾等。直接调⽤String的对应⽅法即可
例如:
2.4 是否是某个特定字符串,某些业务有此需要。
例如: 或者
注意:
这种形式的写法在参数类型是字符串的时候是没有问题的,
但是参数类型为⾮字符串类型的时候就需要写成
仅仅写成也会有很⼤可能会挂。
也许你会说⾮字符串的为什么要写成这样。这就要看特俗需要了。
例如:某⼀个sql⽚段是公⽤的,
该⽚段更新条件也⽤,但是当你需要将某⼀个字段更新成null的时候怎么办。
这个时候就可以通过传⼊⼀个特定的字符串来弄。当传⼊的字符串为特定字符串的时候就更新该字符串为null。
xxx=null
当然这样⼦貌似date型会挂。
通过 2.2 也可以看出mybatis对于字符串的相等不相等的判断也是有对应的特俗操作符的。
el表达式获取map的值eq 对应 ==
neq 对应 !=
当然还可以看出来if的条件判断test是⽀持对象⾃⾝⽅法调⽤的,即使是⾃⼰写的⽅法,可以⾃⼰尝试。当然下⾯会有例⼦。例如:⾥⾯可以⽤‘xxxx’.equals(xxxx) 字符串的⽐较两个字符串⽅法
xxxx.indexOf('ss') 判断字符串⾥⾯是否包含某个字符等等
3 判断list是否为空
上⾯说过,if条件判断可以直接调⽤对象⾃⾝的⽅法进⾏逻辑判断,所以list判空。可以调⽤.size()>0或者.isEmpty()
例如: ,
4 map参数同同理 取值的话 map.key(map中的key名字)即可
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论