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.
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(); } } }
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
Posting Komentar