MybatisPlus怎么使用聚合函数
这篇文章主要介绍了MybatisPlus怎么使用聚合函数的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇MybatisPlus怎么使用聚合函数文章都会有所收获,下面我们一起来看看吧。
首先如果使用sql是这么写的:
ok,既然知道了sql怎么写的,那就开始写代码吧
注意,本文主要以sum为例,但是也同时适用于其他聚合函数,比如avg,min,max
方式1 通过select自定义sql
求一个sum
虽然MybatisPlus没有直接提供对sum函数操作的api,但是QueryWrapper里面有一个select的api,可以支持我们自定义查询sql。
注意:我这种写法需要实体中有这个别名,不然不行的!
那我就直接把代码贴出来了:
publicMapqueryGuaranteeOrderSumAmount(){GuaranteeOrderguaranteeOrder=newGuaranteeOrder();QueryWrapper<GuaranteeOrder>queryWrapper=newQueryWrapper<>();//退款金额总计sum聚合函数queryWrapper.select("sum(refund_amount)refundAmount");//这条订单信息的详情GuaranteeOrderguaranteeOrderDetail=this.getOne(queryWrapper);if(guaranteeOrderDetail==null){guaranteeOrder.setRefundAmount(BigDecimal.valueOf(Double.valueOf(0)));}else{guaranteeOrder.setRefundAmount(guaranteeOrderDetail.getRefundAmount());}HashMap<String,Object>map=newHashMap<>();//退款金额总计map.put("refundSumAmount",guaranteeOrderDetail.getRefundAmount());returnmap;}
可以看到执行的sql是一样的。证明我们的思路和语法是没问题的
求多个sum
那有的小可爱(大聪明)可能就会这么想了,那我要是想sum多个值,是不是再写一个select就可以了,那还真不是!我就是这个大聪明:
如图所示,我又sum了一个字段,但是调用接口的时候,发现一个值是空的:
这其实是错误的!除非再创建一个queryWrapper写select!
正所谓高手怕菜鸟,其实是我们想的太复杂啦,简单的解决方式是:sql怎么写,你就怎么写嘛,直接在后面再拼一个条件就好了,例如:
这次就好啦,解决问题!
方式2 xml手写原生sql
觉得上面的方式比较麻烦,那就可以简单点,直接在mapper(dao).xml里面手写sql
一般项目中都是MybatisPlus和Mybatis同时使用的,就是防止一些关联或者特别麻烦的sql。
关于“MybatisPlus怎么使用聚合函数”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“MybatisPlus怎么使用聚合函数”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注主机评测网行业资讯频道。
下一篇:React?Hooks如何使用
输入法切换键是哪个键?输入法切
冬月是哪一个月?冬月是什么意思
个人所得税退税金额怎么算出来的
输入法全角和半角有什么区别?输
a4纸尺寸是多少厘米?a4纸的由来
个人所得税扣除标准?个人所得税
输入法哪个好用?输入法介绍
卡拉OK是哪个国家发明的?卡拉OK
mikutools原神网页版入口链接?m
关机特别慢什么原因?电脑和手机