Spring Data Rest - 配置findBy路径

问题描述 投票:0回答:2

使用以下存储库:

@RepositoryRestResource(collectionResourceRel = "people", path = "people")
public interface PeopleRepository extends PagingAndSortingRepository<People, String> {

    @RestResource
    List<People> findByName(@Param("name") String name);

}

findByName的URL自动设置为/people/search/findByName。但它似乎相当冗长,可以将URL配置为/people,查询就像/people?name=john

spring jpa spring-data-jpa spring-data spring-data-rest
2个回答
2
投票

如果您使用QueryDSL扩展,您可以使用该格式的查询,并具有能够通过任何属性组合进行过滤而无需编写任何查询方法的额外好处:

配置(假设Maven)

<dependency> 
    <groupId>com.querydsl</groupId> 
    <artifactId>querydsl-apt</artifactId> 
    <version>4.1.4</version>
    </dependency>
<dependency> 
    <groupId>com.querydsl</groupId> 
    <artifactId>querydsl-jpa</artifactId> 
    <version>4.1.4</version> 
</dependency>

然后只需更新您的存储库定义:

@RepositoryRestResource(collectionResourceRel = "people", path = "people")
public interface PeopleRepository extends PagingAndSortingRepository<People, String>, 
                                               QuerydslPredicateExecutor<People> {


}

您现在应该能够过滤:

/people?name=john
/people?name=John&address.town=London 

等等


0
投票

您可以更改路径的最后部分(请参阅doc):

@RestResource(path = "byName", rel = "byName")
List<People> findByName(@Param("name") String name);
/people/search/byName?name=john

有关QueryDsl的全面实现,请参阅@AlanHay答案(更多信息是here

© www.soinside.com 2019 - 2024. All rights reserved.