Spring Data分页与排序的实现方法
前言
在实际项目中对SpringData的各种使用相当多,简单的增删改查SpringData提供了现成的方法,一些复杂的,我们可以在接口方法写And,Not等关键字来搞定,想写原生SQL,CQL(Neo4j),QueryDSL(Elasticsearch)的,直接使用@Query(“......”)注解搞定,真的是方便到不行!
当我们执行批量操作时,比如从数据库中查找“Person”的所有实例或者根据国家查找每个人,我们经常进行分页,以便我们可以向最终用户提供一个小数据块,并在下一个请求中,我们获取下一个数据块。
SpringData为分页提供支持。它创建了实现分页的所有逻辑,例如所有页面的行计数等等。
在SpringData中实现分页非常简单。我们只需要按照以下步骤操作:
- 在自定义存储库中,扩展 PagingAndSortingRepository。
- 创建PageRequest对象,该对象是Pageable接口的实现。 此PageRequest对象获取页码,页面大小以及排序方向和排序字段。
- 通过传递请求的页码和页面限制,您可以获取此页面的数据。如果您传递错误的页码,SpringData将负责处理并且不返回任何数据。
1.创建扩展PagingAndSortingRepository的存储库。
@Repository publicinterfacePersonRepositaryextendsPagingAndSortingRepository,QueryDslPredicateExecutor { @Query("selectpfromPersonpwherep.countrylike?1orderbycountry") List findByCountryContains(Stringcountry); List findPersonByHobbyName(Stringname); @Query("selectpfromPersonpwherep.id=?1andcountry='America'") PersonfindOne(Longid); }
2. 创建域对象。
@Entity
publicclassPerson{
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
privateLongid;
privateStringname;
privateStringcountry;
privateStringgender;
@OneToMany(mappedBy="person",targetEntity=Hobby.class,
fetch=FetchType.EAGER,cascade=CascadeType.ALL)
Listhobby;
publicStringgetName(){
returnname;
}
publicvoidsetName(Stringname){
this.name=name;
}
publicStringgetCountry(){
returncountry;
}
publicvoidsetCountry(Stringcountry){
this.country=country;
}
publicStringgetGender(){
returngender;
}
publicvoidsetGender(Stringgender){
this.gender=gender;
}
publicLonggetId(){
returnid;
}
publicvoidsetId(Longid){
this.id=id;
}
publicListgetHobby(){
returnhobby;
}
publicvoidsetHobby(Listhobby){
this.hobby=hobby;
}
publicvoidaddHobby(Hobbyihobby)
{
if(hobby==null)
{
hobby=newArrayList();
}
hobby.add(ihobby);
}
@Override
publicStringtoString(){
return"Person[id="+id+",name="+name+",country="+country+",gender="+gender+"]";
}
}
3.获取所有人员。创建一个限制为1的PageRequest对象并请求第一页。
@SpringBootApplication
@EnableJpaRepositories("com.example.repo")
publicclassPersonApplication{
@Autowired
HobbyRepositoryhRepo;
privatestaticfinalLoggerlog=LoggerFactory.getLogger(PersonApplication.class);
@Bean
publicCommandLineRunnerdemo(PersonRepositaryrepository){
findAll(repository);
returnnull;
}
privatePageRequestgotoPage(intpage)
{
PageRequestrequest=newPageRequest(page,1)
returnrequest;
}
privatevoidfindAll(PersonRepositaryrepository)
{
IterablepList=repository.findAll(gotoPage(0));
for(Personp:pList)
log.info("Person"+p);
}
publicstaticvoidmain(String[]args){
SpringApplication.run(PersonApplication.class,args);
}
}
运行时SQL输出:
Hibernate:
select
count(person0_.id)ascol_0_0_
from
personperson0_
Hibernate:
select
person0_.idasid1_1_,
person0_.countryascountry2_1_,
person0_.genderasgender3_1_,
person0_.nameasname4_1_
from
personperson0_limit?
PersonPerson[id=13,name=Samirmitra,country=America,gender=male]
分页和排序代码实现
要进行排序,我们必须传递排序方向和排序字段以及页码和限制。假设我们想按国家名称按升序排序-我们修改 goto方法如下:
privatePageRequestgotoPage(intpage)
{
PageRequestrequest=newPageRequest(page,1,Sort.Direction.ASC,"country");
returnrequest;
}
SQL输出:
select
count(person0_.id)ascol_0_0_
from
personperson0_
Hibernate:
select
person0_.idasid1_1_,
person0_.countryascountry2_1_,
person0_.genderasgender3_1_,
person0_.nameasname4_1_
from
personperson0_
orderby
person0_.countryasclimit?
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对毛票票的支持。