2017-01-30 131 views
1

我在项目中使用了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”它显示了上述错误。

+0

您使用的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

+0

当我从我的PageRequest中删除“Direction.DESC”它的作品 –

回答

2

异常消息和documentation of PageRequest应该使您的问题清楚。如果您提供Sort.DirectionPageRequest构造函数,则还必须至少提供一个属性名称(根据应对哪些实体进行排序)。

例如:

PageRequest page_req = new PageRequest(0, last_item, Direction.DESC, "idNode");