具有多个In条件的Spring CrudRepository查询

时间:2019-03-29 20:16:11

标签: java spring-boot spring-data-jpa spring-data amazon-dynamodb

我正在尝试使用Spring Data从dynamodb表中获取数据,并使用In关键字按两个字段进行过滤,但是它总是返回空结果。

我有一个类似的实体:

@DynamoDBTable(tableName = "my-table")
public class MyEntity {
    @Id
    private MyTableKey id;

    private String saleDate;
    private Long sellerId;

    // Some other properties

    @DynamoDBHashKey
    public String getSaleDate() {
        return this.saleDate;
    }

    @DynamoDBRangeKey
    public Long getSellerId() {
        return this.sellerId;
    }
}

我的存储库界面是

@EnableScan
@EnableScanCount
public interface MySalesRepository
        extends PagingAndSortingRepository<MyEntity, MyTableKey> {

    Page<MyEntity> findById (MyTableKey id, Pageable pageable);

    Page<MyEntity> findAllBySaleDateAndSellerIdIn (List<String> saleDate,
            List<Long> sellerId, Pageable pageable);
}

我想获得同时具有saleDate列表中的saleDate和SellerID列表中的SellerId的商品,但是我得到0个结果。

如何使用And和In关键字获取所需的值?

1 个答案:

答案 0 :(得分:3)

尝试更改此内容:

 Page<MyEntity> findAllBySaleDateAndSellerIdIn (List<String> saleDate,
        List<Long> sellerId, Pageable pageable);

对此:

 Page<MyEntity> findBySaleDateInAndSellerIdIn (List<String> saleDate,
        List<Long> sellerId, Pageable pageable);