通過JAVA程式對ORACLE資料庫進行操作並匯出序列(SEQUENCE)
阿新 • • 發佈:2020-11-26
技術標籤:lambdastreamsparkjavafilter
建立一個測試類:
package com.nf147.demo.entity; import lombok.Data; import java.util.List; @Data public class TestVO { /** * 主鍵 */ private long id; /** * 姓名 */ private String name; /** * 年齡 */ private int age; public TestVO() { } public TestVO(long id, String name, int age) { this.id = id; this.name = name; this.age = age; } public static void printStudents(List<TestVO> testVOS){ System.out.println("-------------------------------"); testVOS.forEach(s->System.out.println(s.toString())); System.out.println(" "); } }
list轉為map
// 將list轉為map(並解決重複key問題)
public static void Test(List<TestVO> list) {
Map<Long, Integer> map1 = list.stream().collect(Collectors.toMap(TestVO::getId, TestVO::getAge, (v1, v2) -> v1));
System.out.println("轉為map的資料為" + map1);
}
根據指定條件過濾
//過濾指定查詢條件(查詢age>15並且age<18的資料) public static void Test1(List<TestVO> list) { List<TestVO> collect = list.stream().filter((e) -> e.getAge() > 15 && e.getAge() < 18 ).collect(Collectors.toList()); System.out.println("過濾後的資料為"); TestVO.printStudents(collect); }
根據指定列分組
public static void Test2(List<TestVO> list) {
Map<Integer, List<TestVO>> map = list.stream().collect(Collectors.groupingBy(TestVO::getAge));
System.out.println("根據指定列分組" + map);
}
通過map獲取指定列集合
public static void Test3(List<TestVO> list) { List<Integer> ageList = list.stream() .map(TestVO::getAge) .collect(Collectors.toList()); System.out.println("通過map獲取指定年齡列集合" + ageList); }
根據 List 中 Object 某個屬性去重
public static void Test4() {
//測試資料,請不要糾結資料的嚴謹性
List<TestVO> list = new ArrayList<>();
list.add(new TestVO(1, "李小明", 18));
list.add(new TestVO(2, "李小明", 19));
list.add(new TestVO(3, "王大朋", 16));
list.add(new TestVO(4, "陳小跑", 10));
// 這裡我們引入了兩個靜態方法,以及通過 TreeSet<> 來達到獲取不同元素的效果
// 1. import static java.util.stream.Collectors.collectingAndThen;
// 2. import static java.util.stream.Collectors.toCollection;
ArrayList<TestVO> collect = list.stream().collect(collectingAndThen(toCollection(() -> new TreeSet<>(Comparator.comparing(TestVO::getName))), ArrayList::new));
TestVO.printStudents(collect);
/*
----------------------------------------------------------
TestVO(id=1, name=李小明, age=18)
TestVO(id=3, name=王大朋, age=16)
TestVO(id=4, name=陳小跑, age=10)*/
}
//list統計(求和、最大、最小、平均)
public static void Test5() {
//測試資料,請不要糾結資料的嚴謹性
List<TestVO> list = new ArrayList<>();
list.add(new TestVO(1, "李小明", 18));
list.add(new TestVO(2, "李小明", 19));
list.add(new TestVO(3, "王大朋", 16));
list.add(new TestVO(4, "陳小跑", 10));
double sum = list.stream().mapToDouble(TestVO::getAge).sum();//和
OptionalDouble max = list.stream().mapToDouble(TestVO::getAge).max();//最大
OptionalDouble min = list.stream().mapToDouble(TestVO::getAge).min();//最小
OptionalDouble average = list.stream().mapToDouble(TestVO::getAge).average();//平均值
System.out.println("和" + sum);
System.out.println("最大" + max.getAsDouble());
System.out.println("最小" + min.getAsDouble());
System.out.println("平均值" + average.getAsDouble());
/* 和63.0
最大19.0
最小10.0
平均值15.75*/
}
測試:
//java8 stream 過濾、排序、求和、分組、去重等方法使用和說明
public static void main(String[] args) {
//測試資料,請不要糾結資料的嚴謹性
List<TestVO> list = new ArrayList<>();
list.add(new TestVO(1, "李小明", 18));
list.add(new TestVO(2, "張小麗", 19));
list.add(new TestVO(3, "王大朋", 16));
list.add(new TestVO(4, "陳小跑", 10));
list.stream().forEach(System.out::println);
//按年齡排序(Integer型別)預設是升序,reversed()為降序
List<TestVO> ageList1 = list.stream().sorted(Comparator.comparing(TestVO::getAge).reversed()).collect(Collectors.toList());
TestVO.printStudents(ageList1);
}