加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java-如何获取流的最大索引值

发布时间:2020-12-14 19:25:50 所属栏目:Java 来源:网络整理
导读:我正在使用包含自动生成的id值的Entity类,如下所示, @Entity@Table(name="BlogUser")public class User { @Id @GeneratedValue(strategy=GenerationType.AUTO) @Column private Long id; @Column private String username; 我尝试使用JpaRepository接口在Use

我正在使用包含自动生成的id值的Entity类,如下所示,

@Entity
@Table(name="BlogUser")
public class User {

    @Id
    @GeneratedValue(strategy=GenerationType.AUTO)
    @Column
    private Long id;

    @Column
    private String username;

我尝试使用JpaRepository接口在User类中获取id的最大值.
这是示例代码.

UserJpaRepository.findAll().stream().count();

但是此行仅返回简单的计数值,而不返回User类ID值的最大值.如何使用流功能在User实体类中获取最大id值?

最佳答案
您可以使用Stream.max找到它,例如:

Long maxId = UserJpaRepository.findAll().stream()
    .map(User::getId) // mapping to id
    .max(Comparator.naturalOrder()) // max based on natural comparison
    .orElse(Long.MIN_VALUE); // if nothing element is mapped

或简单地作为

long maxId = UserJpaRepository.findAll().stream()
    .mapToLong(User::getId) // map to id
    .max() // find max
    .orElse(Long.MIN_VALUE);

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读