Langsung ke konten utama

Springboot List object to page Pagination

Paging sering dipakai untuk mengakali performance aplikasi dalam mengkolek data agar tidak semua data ditampilkan ke dalam aplikasi, dengan mengkelompokan datanya kedalam bentuk nomor page.


ada banyak cara untuk membuat pagination ada yang manual dengan menggunakan raw query sql, pakai limit kalau mysql, dan menggunkan top untuk sql server, itu cara manual ada lagi cara yang otomatis pakai liblary seperti spring pakai Page dan Pageable untuk pagination nya dan di implement di ketika call database di repository/dao.


namun disini saya mau coba pakai metode dapetin dulu List object nya dulu lalu kita paging. enak nya pakai cara ini kita bisa paging semua bentuk List object, mau itu object entity atau bukan object entity.


disini saya menggunakan PageListHolder dari spring framework atau spring boot juga ada, karna spring framework include di spring boot.


oke disini, saya coba convert dari List<NamaClass> ke Page<NamaKelas> dan menggunakan Pageable untuk filter dan sortingnya. Disini saya coba membuat file java utils yang memiliki 1 method untuk convert. dan kalau mau dimembuat jadi dynamic (yg nanti bisa passing berbagai class ke method kita) bisa pakai Generic di java. 

how to: 

buat package utils dan buat file class java bebas mau namain apa. disini saya namain classnya MyUtils.java

public class MyUtils {
    public static <E> Page<E> returnPagedList(Pageable pageable, List<E> listOfEntities) {
        final PagedListHolder pagedListHolder = new PagedListHolder(listOfEntities);

        pagedListHolder.setPage(pageable.getPageNumber());
        pagedListHolder.setPageSize(pageable.getPageSize());

        final List<MutableSortDefinition> sortDefinitions = new ArrayList<>();

        final Sort pageableSort = pageable.getSort();
        if (pageableSort != null) {

            Iterator<Sort.Order> iterator = pageableSort.iterator();
            while (iterator.hasNext()) {
                final Sort.Order order = iterator.next();
                MutableSortDefinition sortDefinition = new MutableSortDefinition();
                sortDefinition.setProperty(order.getProperty());
                sortDefinition.setAscending(order.isAscending());
                sortDefinitions.add(sortDefinition);
            }
        }

        sort(pagedListHolder, sortDefinitions);
        pagedListHolder.setPage(pageable.getPageNumber());
        return new PageImpl<E>(pagedListHolder.getPageList(), pageable, listOfEntities.size());
    }
    private static void sort(final PagedListHolder pagedListHolder,
                             final List<MutableSortDefinition> sortDefinitions) {
        for (MutableSortDefinition definition : sortDefinitions) {
            pagedListHolder.setSort(definition);
            pagedListHolder.resort();
        }
    }
}

ini class untuk modelnya: 
private static class Person {
        private String name;
        private int age;
        
        public static Person of(String name, int age) {
            Person person = new Person();
            person.setName(name);
            person.setAge(age);
            return person;
        }
        
        public String getName() {
            return name;
        }
        
        public void setName(String name) {
            this.name = name;
        }
        
        public int getAge() {
            return age;
        }
        
        public void setAge(int age) {
            this.age = age;
        }
        
        @Override
        public String toString() {
            return "Person{" +
                    "name='" + name + '\'' +
                    ", age=" + age +
                    '}';
        }
    }


cara pakai nya seperti ini: 

final List<Person> personList = Arrays.asList(
                Person.of("cui", 188),
                Person.of("cui", 8888),
                Person.of("ac", 22),
                Person.of("bc", 66));
        
        
        Sort sortName = new Sort(Direction.ASC, "name");
        Sort sortAge = new Sort(Direction.ASC, "age");
        
        
        PageRequest pageable = new PageRequest(1, 2, sortAge);
        
        final Page<Person> currentPage = getCurrentPage(pageable, personList);
        System.out.println(out(currentPage));
        System.out.println("isLast:" + currentPage.isLast());
        System.out.println("isFirst:" + currentPage.isFirst());

 




Komentar

Postingan populer dari blog ini

whois

  Pengertian:  whois adalah tools yang digunakan untuk melihat informasi mengenai kepemilikan domain dan website. ICANN meregulasikan domain name dan kepemelikian, tapi record listnya di adakan di semua company dikenal sebagai registrasi.  jadi orang bisa query list of records, dan register akan menghandle request anda dan mengirim detail dari whois record yang sesuai. How to Install whois :  sudo apt-get install whois How to use:  whois cnn.com dan hasilnya akan seperti ini. Domain Name: CNN.COM Registry Domain ID: 3269879_DOMAIN_COM-VRSN Registrar WHOIS Server: whois.corporatedomains.com Registrar URL: http://www.cscglobal.com/global/web/csc/digital-brand-services.html Updated Date: 2018-04-10T16:43:38Z Creation Date: 1993-09-22T04:00:00Z Registry Expiry Date: 2026-09-21T04:00:00Z Registrar: CSC Corporate Domains, Inc. Registrar IANA ID: 299 Registrar Abuse Contact Email: domainabuse@cscglobal.com Registrar Abuse Contact Phone: 8887802723 Domain Status: clien...

Membuat export dan import Excel di spring boot

Membuat export dan import Excel  di spring boot           Adakalanya seorang developer diminta untuk membuat fitur export dan import berbentuk excel dan sebenarnya java sudah menyediakan suatu liblary yang memudahkan kita untuk bekerja dengan MS-Office yaitu Apache POI. Disini saya akan menggunakan Apache POI untuk membaca dan menulis Excel. Catatan : Disini saya sarankan untuk belajar Apache POI Excel terlebih dahulu agar anda mengerti kode yang saya buat di bawah ini. Bahan : -  IntelliJ IDEA -  PostgreSQL -  Maven -  Java 8 Jika sudah tersedia bahan - bahan di atas langsung saja kunjungi situs ini Tambahkan dependency Apache POI di pom.xml seperti di bawah ini. <?xml version="1.0" encoding="UTF-8"?> <project xmlns= "http://maven.apache.org/POM/4.0.0" xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation= "http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0...

Cara dualboot phoenix os dengan Linux Mint, Ubuntu

Cara dualboot phoenix os dengan Linux Mint, Ubuntu               PhonixOS adalah system operasi base android, yang membuat komputer kita sebagai android dengan tampilan desktop yang elegan, dan sangat frendly sumber daya. Disini saya akan share cara dualboot phoenix os dengan Linux mint atau ubuntu dan tuturanan lainnya. Bahan : - PhoenixOs (Download yang format .iso) - Ubuntu atau Linux mint Cara : extract os phoenix yang benbentuk .iso seperti ini Buka terminal lalu ketikan perintah dibawah ini. sudo mkdir /phoenix   sudo cd /phoenix sudo thunar lalu pindah file yang tadi sudah di extart ke /phoenix os yang sudah open as root open terminal lagi dan ketikan sudo dd if=/dev/zero of=/phoenix/data.img bs=1M count=32768 lalu ketikan  sudo mkfs.ext4 /phoenix/data.img  dan setelah kita selesai install phoenix os kita blum membuat grub untuk mmebuat pilihan...