时间:2021-05-20
前言
在实际项目中对Spring Data的各种使用相当多,简单的增删改查Spring Data提供了现成的方法,一些复杂的,我们可以在接口方法写And,Not等关键字来搞定,想写原生SQL,CQL(Neo4j),Query DSL (Elasticsearch)的,直接使用@Query(“......”)注解搞定,真的是方便到不行!
当我们执行批量操作时,比如从数据库中查找“Person”的所有实例或者根据国家查找每个人,我们经常进行分页,以便我们可以向最终用户提供一个小数据块,并在下一个请求中,我们获取下一个数据块。
Spring Data为分页提供支持。它创建了实现分页的所有逻辑,例如所有页面的行计数等等。
在Spring Data中实现分页非常简单。我们只需要按照以下步骤操作:
1.创建扩展PagingAndSortingRepository的存储库。
@Repositorypublic interface PersonRepositary extends PagingAndSortingRepository<Person, Long>,QueryDslPredicateExecutor<Person> { @Query("select p from Person p where p.country like ?1 order by country") List<Person> findByCountryContains(String country); List<Person> findPersonByHobbyName(String name); @Query("select p from Person p where p.id = ?1 and country='America'") Person findOne(Long id);}2. 创建域对象。
@Entitypublic 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> 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<Hobby> getHobby() { return hobby;}public void setHobby(List<Hobby> hobby) { this.hobby = hobby;}public void addHobby(Hobby ihobby){ if(hobby == null) { hobby = new ArrayList<Hobby>(); } hobby.add(ihobby);} @Override 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<Person> 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 方法如下:
private 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 ?
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了ASP.NetMVC+DataTable实现分页+排序功能的方法。分享给大家供大家参考,具体如下:实现思路:使用datatable内置的分页,排序
利用Spring工厂加载机制,实例化ApplicationContextInitializer实现类,并排序对象集合。关键方法privateCollection
本文实例讲述了java实现快速排序的方法。分享给大家供大家参考。具体实现方法如下:publicclassQuick{publicstaticint[]Data=
最近在使用ASP.net2.0的GridView控件时,发现排序与分页功能Microsoft实现的都很简单,比如排序,在点击列名的时候来触发整页的PostBac
本文实例讲述了PHP数组递归排序实现方法。分享给大家供大家参考,具体如下:/***递归根据特定key对数组排序*@param$data*@paramstring