1. 程式人生 > 資料庫 >通過JAVA程式對ORACLE資料庫進行操作並匯出序列(SEQUENCE)

通過JAVA程式對ORACLE資料庫進行操作並匯出序列(SEQUENCE)

技術標籤: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);

    }