1、表结构
package com.example.demo;
import lombok.Data;
import java.math.BigDecimal;
//java项目www.fhadmin.org
@Data
public class User {
private Long id;
private int age;
private String name;
private BigDecimal money;
private String department;
}
2、方法
List<User> list = this.findAll();
java项目www.fhadmin.org
// 获取id的集合 其他字段获取类似 getId换成想要的字段名即可
List<Long> ids = list.stream().map(User::getId).collect(Collectors.toList());
// 返回年龄最大的用户是多少岁 注意:实体类中是int 这边是Integer接的
Integer biggestAge = list.stream().map(User::getAge).max(Integer::compare).get();
// 返回年龄大于20岁的用户集合
List<User> lg20 = list.stream().filter(item -> {
return item.getAge()>20;
}).collect(Collectors.toList());
//根据年龄降序排序用户 默认升序 加上reversed()方法就是降序
List<User> sortByAge = list.stream().sorted(Comparator.comparing(User::getAge).reversed()).collect(Collectors.toList());
// 根据部门分组
Map<String,List<User>> map = list.stream().collect(Collectors.groupingBy(User::getDepartment));
// 统计用户月薪之和 BigDecimal相加从0开始 所以是BigDecimal.ZERO
BigDecimal totalAdd = list.stream().map(User::getMoney).reduce(BigDecimal.ZERO, BigDecimal::add);
// BigDecimal相乘 注意这边是 BigDecimal.ONE
BigDecimal totalMultiply = list.stream().map(User::getMoney)(BigDecimal.ONE, BigDecimal::multiply)
// 顺便说一下 BigDecimal 如何比较大小
BigDecimal a = new BigDecimal(10);
BigDecimal b = new BigDecimal(11);
//使用compareTo方法比较
//注意:a、b均不能为null,否则会报空指针
if (a.compareTo(b) == 0) {
System.out.println("a等于b");
}
if (a.compareTo(b) == -1) {
System.out.println("a小于b");
}
if (a.compareTo(b) == 1) {
System.out.println("a大于b");
}
if (a.compareTo(b) > -1) {
System.out.println("a大于等于b");
}
if (a.compareTo(b) < 1) {
System.out.println("a小于等于b");
}