Mybatis-Plus sum聚合函数及按日期查询并求和的方式详解
作者:m0_55070913 发布时间:2022-07-09 12:58:07
标签:Mybatis-Plus,sum,聚合函数,日期查询
一.Mybatis-Plus——sum聚合函数
//总收益
Order order =new Order();
QueryWrapper<Order> queryWrapper = new QueryWrapper<Order>();
queryWrapper.select("sum(price) as sumAll");
Order ord= orderService.getOne(queryWrapper);
//注意,空指针问题
if (ord== null){
order.setSumAll(Double.valueOf(0)) ;
}else{
order.setSumAll(ord.getSumAll());
}
对应的sql语句是
SELECT sum(price) as sumAll FROM t_order
注意:as后面的变量要与实体类中声明的一致, @TableField(exist = false)表示表中并没有相应的字段与之对应。
(queryWrapper的getOne()方法:根据 Wrapper,查询一条记录)
/**
* 总收益
*/
@TableField(exist = false)
private Double sumAll;
二.按日期查询并求和(mybatis及mybatisPlus两种方式)
举例: 今日总收益
1.mybatisPlus,只需在controller层进行代码书写
//今日总收益
QueryWrapper<Order> queryWrapper = new QueryWrapper<Order>();
queryWrapper.select("sum(price) as sumByToday ");
queryWrapper.eq("TO_DAYS(create_time)","TO_DAYS(NOW())");
Order order =new Order();
if (orderService.getOne(queryWrapper) == null){
order.setSumByToday(Double.valueOf(0)) ;
}else{
order.setSumByToday(orderService.getOne(queryWrapper).getSumByToday());
}
2.mybatis (自己定义sql,简单灵活,但代码量相较于mybatisPlus多了几行)
controller层
//今日总收益
Double sumByToday =orderService.sumByToday();
if (sumByToday == null){
sumByToday = Double.valueOf(0);
}
order.setSumByToday(sumByToday);
service层
Double sumByToday();
service实现层
@Override
public Double sumByToday(){
return orderMapper.sumByToday();
}
mapper层
Double sumByToday();
xml文件
<select id="sumByToday" resultType="java.lang.Double">
select sum(price) as sumByToday from t_order
where TO_DAYS(create_time) = TO_DAYS(NOW())
</select>
3.bug记录,错误信息如下:
Mapper method 'mapper.OrderMapper.sumByToday attempted to return null from a method with a primitive return type (double).
查询出来的值为空,它的数据为null而不是double数据。
解决方法:
方法1:实体类中用来接收“今日总收益“的变量,类型变成封装类Double(Integer、Long,而不是double。
方法2:xml文件中的sql语句变成
select IFNULL(sum(price),0) as sumByToday
from t_order
where TO_DAYS(create_time) = TO_DAYS(NOW())
IFNULL(expression, value):如果第一个参数的表达式 expression 为 NULL,则返回第二个参数的备用值。
来源:https://blog.csdn.net/m0_55070913/article/details/123664970


猜你喜欢
- 基于SMTP发送一个简单的邮件首先,需要一个认证器:package No001_基于SMTP的文本邮件;import javax.mail.
- 本文实例为大家分享了Java实现简单万年历的具体代码,供大家参考,具体内容如下1 要求1、输入年份;2、输入月份;3、输出某年某月的日历。2
- String和List<String>间相互转换public void test() {  
- Java调用Oracle存储过程详解步骤:1、编写Oracle存储过程2、编写数据库获取连接工具类3、编写简单应用调用存储过程实现:1、Or
- 本文实例为大家分享了java自定义异常打印内容的具体代码,供大家参考,具体内容如下背景:在开发中,我们可能会使用到自定义异常,但是,这个自定
- 项目中有几个batch需要检查所有的用户参与的活动的状态,以前是使用分页,一页一页的查出来到内存再处理,但是随着数据量的增加,效率越来越低。
- 本文所述为C#事务处理(Execute Transaction)的一个实例,包含了创建SqlTransaction 对象并用SqlConne
- SSM Mapper查询出返回数据查不到个别字段原因开启了驼峰命名法则,Bean里的字段不识别_注释掉或者把实体类里的字段_去掉换位大写SS
- 在windows环境下,我们通常在IDE如VS的工程中开发C++项目,对于生成和使用静态库(*.lib)与动态库(*.dll)可能都已经比较
- 本文实例讲述了Android模拟器实现手机添加文件到sd卡的方法。分享给大家供大家参考,具体如下:在DDMS中直接添加文件到模拟器sd卡如果
- 本文实例讲解了通知Notification使用方法,此知识点就是用作通知的显示,包括振动、灯光、声音等效果,分享给大家供大家参考,具体内容如
- 一、Intent的用途Intent主要有以下几种重要用途: 1. 启动Activity:可以将Intent对象传递给startActivit
- Comparable 比较器,内置定义的比较方法,实现比较 较简单Comparator 策略模式,需要定义不同的策略和比较的对象,实现比较
- Android用SharedPreferences实现登录注册注销功能前言本文用SharedPreferences本地缓存账号信息来实现登录
- 本文实例讲述了C#动态加载dll扩展系统功能的方法。分享给大家供大家参考。具体分析如下:动态加载dll,主要是为了扩展功能,增强灵活性而实现
- BeanFactory接口:IoC容器的顶级接口,是IoC容器的最基础实现,也是访问Spring容器的根接口,负责对bean的创建,访问等工
- Java未被捕获的异常在你学习在程序中处理异常之前,看一看如果你不处理它们会有什么情况发生是很有好处的。下面的小程序包括一个故意导致被零除错
- 我就废话不多说了,大家还是直接看代码吧~ string url = "https://cloud.soei.com.cn/smsa
- 前言在我们的日常的编程当中,并发是始终离不开的主题,而在并发多线程当中,线程池又是一个不可规避的问题。多线程可以提高我们并发程序的效率,可以
- Bluetooth结构1、JAVA层frameworks/base/core/java/android/bluetooth/包含了bluet