PagingAndSortingRepository接口继承于CrudRepository接口,拥有CrudRepository接口的所有方法,并新增两个功能:分页和排序。但是这两个方法不能包含筛选条件。
接口声明
/**
* PagingAndSortingRepository 接口使用
* 定义的方法名称 参考文档定义
* 提供分页和排序功能
*/
public interface UserDao extends PagingAndSortingRepository {
}
分页功能
分页功能肯定是我们开发中必备的功能了,实现如下:
@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 p = this.usersDao.findAll(pageable);
System.out.println('数据的总条数:'+p.getTotalElements());
System.out.println('总页数:'+p.getTotalPages());
通达信python交易接口,list 通达信python交易接口,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 list = (List)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 list = (List)this.usersDao.findAll(sort);
for (Users users : list) {
System.out.println(users);
}
}
}
单条件排序
文章为作者独立观点,不代表 股票程序化软件自动交易接口观点