PagingAndSortingRepository 接口继承于 CrudRepository 接口,拥有CrudRepository 接口的所有方法, 并新增两个功能:分页和排序。 但是这两个方法不能包含筛选条件。
PagingAndSortingRepository接口
接口声明
/** * PagingAndSortingRepository 接口使用 * 定义的方法名称 参考文档定义 * 提供分页和排序功能 */ public interface UserDao extends PagingAndSortingRepository<Users,Integer> { }
分页功能
分页功能肯定是我们开发中必备的功能了,实现如下:
@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration("classpath:applicationContext.xml") public class TestDemo { @Autowired private UserDao usersDao; /** * 分页 */ @Test public void test1(){ int page = 0; //page:当前页的索引。注意索引都是从 0 开始的。 int size = 3;// size:每页显示 3 条数据 PageRequest pageable= new PageRequest(page, size); Page<Users> p = this.usersDao.findAll(pageable); System.out.println("数据的总条数:"+p.getTotalElements()); System.out.println("总页数:"+p.getTotalPages()); List<Users> list = p.getContent(); for (Users users : list) { System.out.println(users); } } }
排序功能
@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration("classpath:applicationContext.xml") public class TestDemo { @Autowired private UserDao usersDao; /** * 对单列做排序处理 */ @Test public void test2(){ //Sort:该对象封装了排序规则以及指定的排序字段(对象的属性来表示) //direction:排序规则 //properties:指定做排序的属性 Sort sort = new Sort(Sort.Direction.DESC,"userid"); List<Users> list = (List<Users>)this.usersDao.findAll(sort); for (Users users : list) { System.out.println(users); } } /** * 多列的排序处理 */ @Test public void test3(){ //Sort:该对象封装了排序规则以及指定的排序字段(对象的属性来表示) //direction:排序规则 //properties:指定做排序的属性 Sort.Order order1 = new Sort.Order(Sort.Direction.DESC,"userage"); Sort.Order order2 = new Sort.Order(Sort.Direction.ASC,"username"); Sort sort = new Sort(order1,order2); List<Users> list = (List<Users>)this.usersDao.findAll(sort); for (Users users : list) { System.out.println(users); } } }
单条件排序
多条件排序