在上一篇文章中,我们有机会发布了一些基本的DynamoDB查询操作。
但是,除了基本操作之外,DynamoDB api还为我们提供了一些额外的功能。
投影是具有类似选择功能的功能。
您选择应从DynamoDB项中提取哪些属性。 请记住,使用投影不会对您的查询帐单产生任何影响。
public Map<String,AttributeValue> getRegisterDate(String email) {
Map<String,String> expressionAttributesNames = new HashMap<>();
expressionAttributesNames.put("#email","email");
Map<String,AttributeValue> expressionAttributeValues = new HashMap<>();
expressionAttributeValues.put(":emailValue",new AttributeValue().withS(email));
QueryRequest queryRequest = new QueryRequest()
.withTableName(TABLE_NAME)
.withKeyConditionExpression("#email = :emailValue")
.withExpressionAttributeNames(expressionAttributesNames)
.withExpressionAttributeValues(expressionAttributeValues)
.withProjectionExpression("registerDate");
QueryResult queryResult = amazonDynamoDB.query(queryRequest);
List<Map<String,AttributeValue>> attributeValues = queryResult.getItems();
if(attributeValues.size()>0) {
return attributeValues.get(0);
} else {
return null;
}
}
除了选择属性,我们还可以根据我们的范围键指定顺序。 我们将使用scanIndexForward以降序查询登录表。
public List<Map<String,AttributeValue>> fetchLoginsDesc(String email) {
List<Map<String,AttributeValue>> items = new ArrayList<>();
Map<String,String> expressionAttributesNames = new HashMap<>();
expressionAttributesNames.put("#email","email");
Map<String,AttributeValue> expressionAttributeValues = new HashMap<>();
expressionAttributeValues.put(":emailValue",new AttributeValue().withS(email));
QueryRequest queryRequest = new QueryRequest()
.withTableName(TABLE_NAME)
.withKeyConditionExpression("#email = :emailValue")
.withExpressionAttributeNames(expressionAttributesNames)
.withExpressionAttributeValues(expressionAttributeValues)
.withScanIndexForward(false);
Map<String,AttributeValue> lastKey = null;
do {
QueryResult queryResult = amazonDynamoDB.query(queryRequest);
List<Map<String,AttributeValue>> results = queryResult.getItems();
items.addAll(results);
lastKey = queryResult.getLastEvaluatedKey();
} while (lastKey!=null);
return items;
}
数据库的常见功能是对集合中保留的项目进行计数。 在我们的情况下,我们要计算特定用户的登录次数。 但是,请特别注意,因为计数功能只不过是对已提取的项目总数进行计数,因此,这将使您像在提取项目一样花费很多。
public Integer countLogins(String email) {
List<Map<String,AttributeValue>> items = new ArrayList<>();
Map<String,String> expressionAttributesNames = new HashMap<>();
expressionAttributesNames.put("#email","email");
Map<String,AttributeValue> expressionAttributeValues = new HashMap<>();
expressionAttributeValues.put(":emailValue",new AttributeValue().withS(email));
QueryRequest queryRequest = new QueryRequest()
.withTableName(TABLE_NAME)
.withKeyConditionExpression("#email = :emailValue")
.withExpressionAttributeNames(expressionAttributesNames)
.withExpressionAttributeValues(expressionAttributeValues)
.withSelect(Select.COUNT);
Map<String,AttributeValue> lastKey = null;
QueryResult queryResult = amazonDynamoDB.query(queryRequest);
List<Map<String,AttributeValue>> results = queryResult.getItems();
return queryResult.getCount();
}
DynamoDB的另一个功能是批量获取项目,即使它们属于不同的表也是如此。 在属于特定上下文的数据通过不同的表分布的情况下,这确实很有用。 每个获取项都作为DynamoDB读取操作进行处理和收费。 如果是批量获取项,则应指定所有表键,因为BatchGetItem的每个查询的目的都是获取单个项。
public Map<String,List<Map<String,AttributeValue>>> getMultipleInformation(String email,String name) {
Map<String,KeysAndAttributes> requestItems = new HashMap<>();
List<Map<String,AttributeValue>> userKeys = new ArrayList<>();
Map<String,AttributeValue> userAttributes = new HashMap<>();
userAttributes.put("email",new AttributeValue().withS(email));
userKeys.add(userAttributes);
requestItems.put(UserRepository.TABLE_NAME,new KeysAndAttributes().withKeys(userKeys));
List<Map<String,AttributeValue>> supervisorKeys = new ArrayList<>();
Map<String,AttributeValue> supervisorAttributes = new HashMap<>();
supervisorAttributes.put("name",new AttributeValue().withS(name));
supervisorKeys.add(supervisorAttributes);
requestItems.put(SupervisorRepository.TABLE_NAME,new KeysAndAttributes().withKeys(supervisorKeys));
BatchGetItemRequest batchGetItemRequest = new BatchGetItemRequest();
batchGetItemRequest.setRequestItems(requestItems);
BatchGetItemResult batchGetItemResult = amazonDynamoDB.batchGetItem(batchGetItemRequest);
Map<String,List<Map<String,AttributeValue>>> responses = batchGetItemResult.getResponses();
return responses;
}
您可以在github上找到源代码
翻译自: https://www.javacodegeeks.com/2016/07/query-dynamodb-items-java-part-2.html