Spring Data分页与排序的实现方法

网友投稿 290 2023-01-18


Spring Data分页与排序的实现方法

前言

在实际项目中对Spring Data的各种使用相当多,简单的增删改查Spring Data提供了现成的方法,一些复杂的,我们可以在接口方法写And,Not等关键字来搞定,想写原生SQL,CQL(Neo4j),Query DSL (Elasticsearch)的,直接使用@Query(“......”)注解搞定,真的是方便到不行!

当我们执行批量操作时,比如从数据库中查找“Person”的所有实例或者根据国家查找每个人,我们经常进行分页,以便我们可以向最终用户提供一个小数据块,并在下一个请求中,我们获取下一个数据块。

Spring Data为分页提供支持。它创建了实现分页的所有逻辑,例如所有页面的行计数等等。

在Spring Data中实现分页非常简单。我们只需要按照以下步骤操作:

在自定义存储库中,扩展  PagingAndSortingRepository。

创建PageRequest对象,该对象是Pageable接口的实现。  此PageRequest对象获取页码,页面大小以及排序方向和排序字段。

通过传递请求的页码和页面限制,您可以获取此页面的数据。如果您传递错误的页码,Spring Data将负责处理并且不返回任何数据。

1.创建扩展PagingAndSortingRepository的存储库。

@Repository

public interface PersonRepositary extends PagingAndSortingRepository,QueryDslPredicateExecutor {

@Query("select p from Person p where p.country like ?1 order by country")

List findByCountryContains(String country);

List findPersonByHobbyName(String name);

@Query("select p from Person p where p.id = ?1 and country='America'")

Person findOne(Long id);

}

2.  创建域对象。

@Entity

public class Person {

@Id

@GeneratedValue(strategy=GenerationType.AUTO)

private Long id;

private String name;

private String country;

private String gender;

@OneToMany(mappedBy="person",targetEntity=Hobby.class,

fetch=FetchType.EAGER,cascade=CascadeType.ALL)

List hobby;

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public String getCountry() {

return country;

}

public void setCountry(String country) {

this.country = country;

}

public String getGender() {

return gender;

}

public void setGender(String gender) {

this.gender = gender;

}

public Long getId() {

return id;

}

public void setId(Long id) {

this.id = id;

}

public List getHobby() {

return hobby;

}

public void setHobby(List hobby) {

this.hobby = hobby;

}

public void addHobby(Hobby ihobby)

{

if(hobby == null)

{

hobby = new ArrayList();

}

hobby.add(ihobby);

}

@Overridhttp://e

public String toString() {

return "Person [id=" + id + ", name=" + name + ", country=" + country + ", gender=" + gender + "]";

}

}

3.获取所有人员。创建一个限制为1的PageRequest对象并请求第一页。

@SpringBootApplication

@EnableJpaRepositories("com.example.repo")

public class PersonApplication {

@Autowired

HobbyRepository hRepo;

private static final Logger log = LoggerFactory.getLogger(PersonApplication.class);

@Bean

public CommandLineRunner demo(PersonRepositary repository) {

findAll(repository);

return null;

}

private PageRequest gotoPage(int page)

{

PageRequest request = new PageRequest(page,1)

return request;

}

private void findAll(PersonRepositary repository)

{

Iterable pList = repository.findAll(gotoPage(0));

for(Person p : pList)

log.info("Person " + p);

}

public static void main(String[] args) {

SpringApplication.run(PersonApplication.class, args);

}

}

运行时SQL输出:

Hibernate:

    select

        count(person0_.id) as col_0_0_

    from

        person person0_

Hibernate:

    select

        person0_.id as id1_1_,

        person0_.country as country2_1_,

        person0_.gender as gender3_1_,

        person0_.name as name4_1_

    from

        person person0_ limit ?

Person Person [id=13, name=Samir mitra, country=America, gender=male]

分页和排序代码实现

要进行排序,我们必须传递排序方向和排序字段以及页码和限制。假设我们想按国家名称按升序排序 - 我们修改  goto 方法如下:

prhttp://ivate PageRequest gotoPage(int page)

{

PageRequest request = new PageRequest(page,1,Sort.Direction.ASC,"country");

return request;

}

SQL输出:

select

        count(person0_.id) as col_0_0_

    from

        person person0_

Hibernate:

    select

        person0_.id as id1_1_,

        person0_.country as country2_1_,

        person0_.gender as gender3_1_,

        person0_.name as name4_1_

    from

        person person0_

    order by

        person0_.country asc limit ?

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:java实现图片的上传与展示实例代码
下一篇:开发接口管理工具有哪些(java接口管理工具)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~