Spring Data repositories ကို အမျိုးစုံ customize လုပ်ပုံ
ကိုယ့်စိတ်ကြိုက် quries တွေကို Spring Data repositories တွေမှာ ရေးလို့ရပါတယ်။ findBy ဆိုတဲ့ prefix နဲ့ စရမှာဖြစ်ပါတယ်။
ဥပမာ findBy + Brand = findByBrand
ရှေ့က prefix findBy က အသေ ဖြစ်ပြီးနောက်က ကိုယ်ရှာဖို့ ပေးလိုက်ချင်တဲ့ field နာမည်ကိုရေးရမှာပါ။
အောက်မှာ example ပြထားပါတယ်။
import java.util.List;
import org.springframework.data.repository.CrudRepository;
public interface CarRepository extends CrudRepository<Car, Long> {
// Fetch cars by brand
List<Car> findByBrand(String brand);
findBy ဆိုတဲ့ keyword နောက်မှာ And နဲ့ Or ဆိုတဲ့ keyword တွေသုံးလို့ရပါသေးတယ်။
ဥပမာ findBy + Brand + And + Model = findByBrandAndModel
findBy+ Brand + Or + Color = findByBrandOrColor
အစရှိသည်ဖြင့်သုံးနိုင် ရေးနိုင်ပါတယ်။
အောက်မှာ example ပြထားပါတယ်။
package com.packt.demo.domain;
import java.util.List;
import org.springframework.data.repository.CrudRepository;
public interface CarRepository extends CrudRepository<Car, Long> {
// Fetch cars by brand and model
List<Car> findByBrandAndModel(String brand, String model);
// Fetch cars by brand or color
List<Car> findByBrandOrColor(String brand, String color);
}
ဒီထက် advance ဖြစ်တဲ့ keyword နောက် တစ်မျိုးက OrderBy ဆိုတဲ့ keyword ပါ။ ထွက်လာတဲ့ results တွေကို ကြီးရာကနေငယ်ရာ ၊ ငယ်ရာကနေကြီးရာ စီပေးနိုင်ပါတယ်။
အဲဒါကတော့ Asc နဲ့ Desc ဆိုတဲ့ keyword တွေပေါ့။ ဥပမာ findBy+Year+OrderBy+Asc findByYearOrderByAsc ဆိုရင် Year ကိုပေးပြီးရှာမယ်။ ထွက်လာတဲ့ results ကို
ငယ်ရာကနေကြီးရာ စီမယ်ဆိုတဲ့ method ကို create လုပ်နိုင်ပြီပေါ့။
package com.packt.demo.domain;
import java.util.List;
import org.springframework.data.repository.CrudRepository;
public interface CarRepository extends CrudRepository<Car, Long> {
// Fetch cars by brand and sort by year
List<Car> findByBrandOrderByYearAsc(String brand);
}
နောက်ဆုံးတစ်ခုကတော့ method name အစား ကိုယ်ရေးချင်တဲ့ query ကို SQL လိုမျိုး ဟာနဲ့ ဆွဲထုတ်ပြီးရေးတာဖြစ်ပါတယ်။ အောက်မှာ example ကို ပြထားပါတယ်။ ?1 ဆိုတာ positional parameter ပါ။ ဒီနေရာမှာ brand ပေါ့
package com.packt.demo.domain;
import java.util.List;
import org.springframework.data.repository.CrudRepository;
public interface CarRepository extends CrudRepository<Car, Long> {
// Fetch cars by brand using SQL
@Query("select c from Car c where c.brand like %?1")
List<Car> findByBrandEndsWith(String brand);
}
Pagination အတွက်ကတော့ PagingAndSortingRepository ဆိုတဲ့ feature ကို CrudRepository အပြင်သုံးနိုင်ပါတယ်။ ဆွဲထုတ်မယ့် Data တွေ အရမ်းများရင် serverside pagination ဟာ
အင်မတန်အသုံးဝင်ပါတယ်။ PagingAndSortingRepository ဟာ results တွေကို page အလိုက်ထုတ်ပေးဖို့နဲ့ sort လုပ်ပေးတဲ့နေရာမှာ အသုံးဝင်ပါတယ်။ PagingAndSortingRepository ကို
ဆောက်တာ CrudRepository ကို ဆောက်တာနဲ့ ပုံစံတူတူပါပဲ။
ဒါဆိုရင် အောက်ပါ method တွေကို စသုံးနိုင်ပြီဖြစ်ပါတယ်။
Method | Description |
---|---|
Iterable<T> findAll(Sort sort) | ပေးလိုက်တဲ့ sort option အတိုင်း item တွေကိုထုတ်ယူဖို့ |
Page<T> findAll(Pageable | |
pageable) | ပေးလိုက်တဲ့ paging option အတိုင်း item တွေကို ထုတ်ယူဖို့ |
Top comments (0)