iBastis 之count, sum操作

一、count, sum 函数区别

sql里的count() 函数,无匹配的值时,返回的是0;而sum(), max()等函数,返回的是NULL。

执行sql验证如下:
执行 count() 函数:
count 函数

执行 sum() 函数:
sum 函数

二、有数据情况下,是否设置 resultClass的结果

iBatis里,queryForObject() 函数执行的sql未设置resultClass时,会返回一个空的对象。

queryForObject 方法文档

验证如下:
不带resultClass sql :
不带resultClass sql
输出为:
这里写图片描述

带resultClass sql :
带resultClass sql
输出为:
这里写图片描述

三、无数据情况下,是否设置 resultClass的结果

sql写法和上边一样。

结果分别为:
不设置 resultClass:
不设置 resultClass

设置 resultClass:
设置 resultClass

四、结论

count 或者 sum等操作,必须设置 resultClass,且看情况需判断执行 queryForObject 函数返回值是否为空。

五、扩展

ibatis 常用的几种查询方式,无数据情况下返回值:

  • queryForObject: 返回 null
  • queryForList: 返回 [], 即 空的 List, list.isEmpty() == true
  • queryForMap: 返回 {}, 即 空的 Map, map.isEmpty() == true

其中,queryForList 和 queryForMap 和未设置 resultClass 时,仍返回 [] 和 {}。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值