spring bootDao

SpringBoot第六讲扩展和封装Spring Data JP

2016-12-27  本文已影响2680人  孔浩

通过上几讲的内容,我们基本掌握了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的事务、批量更新和关联对象查询的问题。

本文的源代码在这里:源代码

上一篇下一篇

猜你喜欢

热点阅读