Springboot jpa使用sum()函数返回结果如何被接收

 更新时间:2022年02月23日 14:24:29   作者:ununie  
这篇文章主要介绍了Springboot jpa使用sum()函数返回结果如何接收,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

jpa使用sum()返回结果如何接收

1、需求

我的需求是统计域名以及域名出现的次数。

之前使用springboot jpa都是把数据库中的表跟实体类绑定,创建继承JpaRepository的接口。如下:

@Repository
public interface UrlsRepository extends JpaRepository<Urls, String> { 
    Optional<Urls> findById(Integer id);
}

但是对于这种查询却无法绑定到原有的实体类。那么改怎么解决这种需求呢?

2、解决方法一

使用Object[] 数组接收每一行数据,用List<Object[]>接收查询结果。

repository中的写法

    @Query(value = "SELECT domain,sum(visit_count) from Urls GROUP BY domain ORDER BY sum(visit_count) desc", nativeQuery = true)
    List<Object[]> findDomainAndCount();

注意:@Query的nativeQuery属性值默认是false,表示使用JPQL语言。设为true表示使用本地sql(数据库对应的sql)

测试:

    @Test
    public void findDomainAndCount() {
        List<Object[]> list = urlsRepository.findDomainAndCount();
        for (Object[] objs : list) {
            for (int i = 0; i < objs.length; i++) {
                System.out.print(String.valueOf(objs[i]) + ",");
            }
            System.out.println();
        }
    }

结果:

3、解决方法二

用一个包装类来接收查询结果。

@Getter
@Setter
@ToString
public class DomainVo {
    private String domain;
    private Long visitCount; 
    public DomainVo(String domain, Long visitCount) {
        this.domain = domain;
        this.visitCount = visitCount;
    }
}

repository写法

    /*
    注意:
    1、使用的是全类名
    2、查询的表对应的是已经绑定的实体类Urls
    3、nativeQuery设为false,表示使用的是jpql语言。
     */ 
@Query(value = "SELECT new com.ununie.chromehistory.model.vo.DomainVo(u.domain,sum(u.visitCount)) from Urls u GROUP BY u.domain ORDER BY sum(u.visitCount) desc")
    List<DomainVo> findDomainCount();

测试:

    @Test
    public void findDomainCount() {
        List<DomainVo> domainCount = urlsRepository.findDomainCount();
        for (DomainVo vo : domainCount) {
            System.out.println(vo);
        }
    }

结果:

jpa使用count函数和sum函数

最近在使用JPQL时遇到了一个问题,关于count函数和sum函数不知该如何取值,在网上查了查资料,找到了一种解决方法

具体代码如下:

public long getObjectsCountByQueryString(String queryString) {
        //queryString = "select count(o) from MyModel as o"; 
        long count = 0; 
        count = ((Long)getJpaTemplate().find(queryString).get(0)).longValue();
        return count; 
    }      
    public long getObjectsSumByQueryString(String queryString) {
        //queryString = "select sum(o.price) from MyModel as o"; 
        List list = getJpaTemplate().find(queryString);
        //使用sum函数要注意这里要先判断是否为null,不然会出空指针异常,count函数不用判断null
        if(list.get(0) == null){
            return 0;
        }
        else{
            return ((Long)list.get(0)).longValue();
        }
    }

刚开始使用JPA时,基本都依赖@query(SQL)注解通过原生sql来实现

根据编号统计条数:

方法一

@Query(" select count(t) from FollowerInfo t where investUserId = :invUserId")
Integer findFollowerNumberByInvUserId(@Param("invUserId") Long invUserId);

这种原生的方式,跟直接写SQL没什么区别。虽然能实现功能,但是浪费了JPA的简洁简化代码的设计的优点。

网上看到另外一个方法:

List findAll(Specification spec);

在repository层findAll,然后在service层封装,获取list.size()来处理总条数问题。

这样避免了写SQL语句。

今天看了一下CrudRepository的源码 发现该接口源码里面有一个函数:

方法二

/**
* Returns the number of entities available.
*
* @return the number of entities
*/
long count();

于是继承了CrudRepository 写了一个demo:

方法三

Long countByInvestUserId(Long investUserId);

一行代码就全部搞定! 效果跟方法1一样

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • springboot2+es7使用RestHighLevelClient的示例代码

    springboot2+es7使用RestHighLevelClient的示例代码

    本文主要介绍了springboot2+es7使用RestHighLevelClient的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • Java 语言守护线程 Daemon Thread使用示例详解

    Java 语言守护线程 Daemon Thread使用示例详解

    这篇文章主要为大家介绍了Java 语言守护线程 Daemon Thread使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • Java日常练习题,每天进步一点点(10)

    Java日常练习题,每天进步一点点(10)

    下面小编就为大家带来一篇Java基础的几道练习题(分享)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望可以帮到你
    2021-07-07
  • SpringBoot中JPA更新时部分字段无效

    SpringBoot中JPA更新时部分字段无效

    本文主要介绍了SpringBoot中JPA更新时部分字段无效,在通过注解自动更新时,部分字段在调试时可以找到,却没有被自动更新到数据库中,下面就介绍一下解决方法
    2023-04-04
  • 重写Java中的equals方法介绍

    重写Java中的equals方法介绍

    这篇文章主要介绍了重写Java中的equals方法介绍,具有一定参考价值,需要的朋友可以了解下。
    2017-11-11
  • Java实现File转换MultipartFile格式的例子

    Java实现File转换MultipartFile格式的例子

    本文主要介绍了Java实现File转换MultipartFile格式的例子,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-07-07
  • @Data注解在Boolean类型属性上的大坑及解决

    @Data注解在Boolean类型属性上的大坑及解决

    在使用@Data注解时,如果类中存在Boolean类型的属性,且属性名不是以"is"开头,那么@Data注解生成的get方法名会默认加上"is",导致属性值无法成功拷贝,解决方法是手动添加get方法,覆盖@Data注解生成的方法
    2024-10-10
  • Spring Boot如何优雅的使用多线程实例详解

    Spring Boot如何优雅的使用多线程实例详解

    这篇文章主要给大家介绍了关于Spring Boot如何优雅的使用多线程的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Spring Boot具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2020-05-05
  • 聊聊Lombok中的@Builder注解使用教程

    聊聊Lombok中的@Builder注解使用教程

    @Builder注解的作用主要是用来生成对象,并且可以为对象链式赋值。接下来通过本文给大家介绍Lombok中的@Builder注解使用教程,感兴趣的朋友一起看看吧
    2021-11-11
  • Java8 Instant 时间戳实例讲解

    Java8 Instant 时间戳实例讲解

    Instant类是Java8 中补充的一个 时间戳类,nstant 可以使用静态方法 now()或者of()方法来创建一个实例对象,本文通过实例代码讲解Java8 Instant 时间戳,感兴趣的朋友跟随小编一起看看吧
    2022-11-11

最新评论