我是 Dynamo DB 的新手,可能这是一个非常简单的问题,但我查看了Dynamo DB的文档和堆栈溢出问题,但我找不到一个链接,告诉如何查询只有散列键的 GSI 的DDB,并且没有为其指定范围键。
我得到异常非法查询表达式:在查询中找不到散列键条件。
答案 0 :(得分:26)
在DynamoDB注释模型对象上,您应该使用@DynamoDBIndexHashKey(globalSecondaryIndexName = "gsiIndexName)
表示它是GSI的哈希键:
@DynamoDBTable(tableName = "myTable")
public class MyTable {
...
@DynamoDBIndexHashKey(globalSecondaryIndexName = "myGsi")
public String getGsiHk() {
return gsiHk;
}
...
}
然后在query
上使用DynamoDBMapper
方法:
final MyTable gsiKeyObj = new MyTable();
gsiKeyObj.setGsiHk("myGsiHkValue");
final DynamoDBQueryExpression<MyTable> queryExpression =
new DynamoDBQueryExpression<>();
queryExpression.setHashKeyValues(gsiKeyObj);
queryExpression.setIndexName("myGsi");
queryExpression.setConsistentRead(false); // cannot use consistent read on GSI
final PaginatedQueryList<MyTable> results =
mapper.query(MyTable.class, queryExpression);