通过上几讲的内容,我们基本掌握了Spring Data JPA的大量基础操作了,并且也可以完成一些简单的封装,今天我们要解决SpringDataJPA剩下的一些小问题,有如下一些知识点:
- 封装排序操作
- 封装分页操作
在SpringDataJPA中排序操作已经演示的过了,主要是通过Sort类和Order类来组成,Sort对象的创建需要传入Order对象或者Order列表,通过Order确定排序的字段和方式。这种方式在调用起来个人感觉稍微有些麻烦,所以进行了比较简单的封装,封装代码如下:
public class SimpleSortBuilder {
/**
* 调用的时候使用SimpleSortBuilder.generateSort("name","xh_d");表示先以name升序,之后以xh降序
*/
public static Sort generateSort(String... fields) {
List<Order> orders = new ArrayList<Order>();
for(String f:fields) {
orders.add(generateOrder(f));
}
return new Sort(orders);
}
private static Order generateOrder(String f) {
Order order = null;
String[] ff = f.split("_");
if(ff.length>=2) {
if(ff[1].equals("d")) {
order = new Order(Direction.DESC,ff[0]);
} else {
order = new Order(Direction.ASC,ff[0]);
}
return order;
}
order = new Order(f);
return order;
}
}
封装思路很简单,主要是希望通过约定的名称来处理,这样相对简单一些,测试代码如下:
@Test
public void testSort() {
//使用了上一讲封装的Specification的查询
List<Student> stus = studentRepository.findAll(
new SimpleSpecificationBuilder<Student>("address", "=", "zt").generateSpecification(),
SimpleSortBuilder.generateSort("id_d"));
Assert.assertEquals(7, stus.get(0).getId());
}
分页的封装思路就更简单了,个人仅仅只是封装了一个size而已,因为size经常是固定的,其他什么操作都没有做,如果大家有更好的封装方式,欢迎一起交流。
/**
* 仅仅只是对size进行了封装,太过简单
* @author konghao
*
*/
public class SimplePageBuilder {
/**
* 以常量的形式存储,在实际的运用中应该从properties文件中取得,思路都一样
* */
public static final int size = 15;
public static Pageable generate(int page,int size,Sort sort) {
if(sort==null) return new PageRequest(page, size);
return new PageRequest(page, size, sort);
}
public static Pageable generate(int page) {
return generate(page,size,null);
}
public static Pageable generate(int page,Sort sort) {
return generate(page,size,sort);
}
}
以上封装非常的简单,基本没有做任何实质性的操作,以下是测试代码:
@Test
public void testPage() {
//注意:page是从0开始的
Page<Student> stus = studentRepository.findAll(
new SimpleSpecificationBuilder<Student>("address","=","zt").generateSpecification(),
SimplePageBuilder.generate(0, SimpleSortBuilder.generateSort("name_d")));
Assert.assertEquals(1, stus.getTotalPages());
Assert.assertEquals(4, stus.getTotalElements());
Assert.assertEquals(5, stus.getContent().get(0).getId());
}
以上就是个人对分页和排序的封装,在实际的生产环境中使用还是比较顺利的。这里需要特别提一下,在SpringDataJPA中还有一个钟Querydsl的查询方式,这种方式基于对象模型来进行查询的,依然也有很大的余地对其进行封装,有兴趣的朋友可以自己找这部分的知识来学习一下,我们就不详细介绍了。下一讲我们具体解决SpringDataJPA的事务、批量更新和关联对象查询的问题。
本文的源代码在这里:源代码