まず、DynamoDBにはJSONデータ型がありません。データがDynamoDBデータタイプMAP
として保存されている場合は、以下の解決策が有効です。要するに
、フィルタ式は以下のようなものでなければなりません: - あなたは出力にのみ「records.K1」と「records.K2」を持っている必要がある場合は、あなたのために、プロジェクトの表現を使用することができます
FilterExpression : 'records.K1 = :recordsK1Value and records.K2 = :recordsK2Value'
それ。
ProjectionExpression : 'records.K1, records.K2'
全コード: - すべてのフィールドを持つ
public List<String> queryMoviesAndFilterByMapAttribute() {
List<String> moviesJsonList = new ArrayList<>();
DynamoDB dynamoDB = new DynamoDB(dynamoDBClient);
Table table = dynamoDB.getTable("Movies");
QuerySpec querySpec = new QuerySpec();
querySpec.withKeyConditionExpression("yearkey = :yearval and title = :titleval")
//.withProjectionExpression("records.K1, records.K2")
.withFilterExpression("records.K1 = :recordsK1Value and records.K2 = :recordsK2Value").withValueMap(
new ValueMap().withNumber(":yearval", 1991).withString(":titleval", "Movie with map attribute")
.withString(":recordsK1Value", "V1").withString(":recordsK2Value", "V2"));
IteratorSupport<Item, QueryOutcome> iterator = table.query(querySpec).iterator();
while (iterator.hasNext()) {
Item movieItem = iterator.next();
System.out.println("Movie data ====================>" + movieItem.toJSONPretty());
moviesJsonList.add(movieItem.toJSON());
}
return moviesJsonList;
}
サンプル出力(すなわち、プロジェクトの表現なし): - コメント解除後
Movie data ====================>{
"yearkey" : 1991,
"records" : {
"K1" : "V1",
"K2" : "V2",
"K3" : "V3",
"K4" : "V4"
},
"title" : "Movie with map attribute"
}
サンプル出力プロジェクト式: -
yearkey、title、K3、K4などの他のフィールドは出力されません。
Movie data ====================>{
"records" : {
"K1" : "V1",
"K2" : "V2"
}
}
「records」属性のDynamoDBデータタイプとは何ですか?地図ですか? – notionquest
私はgsonのようなものでシリアル化した後、jsonの文字列として2つのタイプを考えていました。 2番目のオプションは、シリアル化することですが、1つの文字列ではなくリストとして格納します。 – chrisrhyno2003