Spring Jpa Data Page PageRequest
我在项目中使用了Spring JPA DATA。我想让我的数据页面。我已经将Pageable添加到我的存储库方法中。但它显示类似这样的错误:Spring Jpa Data Page PageRequest
请求处理失败;嵌套的异常是 java.lang.IllegalArgumentException:您必须提供至少一个 属性进行排序! java.lang.IllegalArgumentException:你必须 提供至少一个属性来排序! org.springframework.data.domain.Sort。 <init>(Sort.java:92) org.springframework.data.domain.Sort。 <init>(Sort.java:80) org.springframework.data.domain.PageRequest。 <初始化>(PageRequest.java:52) com.datum.fnd.controller.rest.NodeRestController.getNodes(NodeRestController.java:44) sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法).....
我想与你分享我的代码。请看下面的代码。我已经找不到在哪里我没有弄错
我@Repository类:
@Query(value = "select new com.datum.fnd.domain.Node(c.idNode, c.name,c.address, c.description, c.point) from Node c")
List<Node> getNodesByPage(Pageable pageable);
我的服务类:
public interface NodeService extends DefaultService<Node, Long> {
List<Node> getUnboundedNodes();
List<Node> getNodes(Pageable pageable);
}
我ServiceImpl类:
@Service
public class NodeServiceImpl implements NodeService {
private static final Logger LOG = Logger.getLogger(NodeServiceImpl.class);
@Autowired
private NodeRepository nodeRepository;
@Autowired
private ChannelNodeRepository channelNodeRepository;
@Override
public Node create(Node node) {
return nodeRepository.save(node);
}
@Transactional(readOnly = true)
@Override
public List<Node> list() {
return nodeRepository.selectAll();
}
@Transactional(readOnly = true)
@Override
public List<Node> getNodes(Pageable pageable) {
return nodeRepository.getNodesByPage(pageable);
}
我的控制器类:
@RequestMapping(value = "/page/{last_item}", method = RequestMethod.GET)
public List<Node> getNodes(@PathVariable(value = "last_item") int last_item) {
LOG.info("Retrieve all nodes");
PageRequest page_req = new PageRequest(0, last_item, Direction.DESC);
return nodeService.getNodes(page_req);
}
,当我尝试叫“http://localhost:8088/FNDWEB/rest/node/page/50”它显示了上述错误。
异常消息和documentation of PageRequest应该使您的问题清楚。如果您提供Sort.Direction
至PageRequest
构造函数,则还必须至少提供一个属性名称(根据应对哪些实体进行排序)。
例如:
PageRequest page_req = new PageRequest(0, last_item, Direction.DESC, "idNode");
您使用的PageRequest构造似乎需要第四个非空参数http://docs.spring.io/autorepo/docs/spring-data-commons/ 1.13.0.M1/api/org/springframework/data/domain/PageRequest.html#PageRequest-int-int-org.springframework.data.domain.Sort.Direction-java.lang.String ...- – RubioRic
当我从我的PageRequest中删除“Direction.DESC”它的作品 –