Podmiot, którego szukam, ma HashKey
& a RangeKey
(liczba). Gdy używam batchGetItem
na nim, pojawia się następujący błąd:Błąd w API batchGetItem w java
AWS Error Code: ValidationException, AWS Error Message: One or more parameter values were invalid: Mismatching attribute types between location and schema
Schema:
Table: Daily
Hash Key: CustId (String)
Range Key: Dated (Number)
danych:
CustId : VisioNerdy
Dated : 1329071400000
Kod:
List<Key> fkeys = new ArrayList<Key>(); //tableName="Daily", keys=["VisioNerdy"], ranges=[1329071400000] Map<String, KeysAndAttributes> requestItems = new HashMap<String, KeysAndAttributes>(); for(int i = 0; i < keys.size(); i++) { String key = keys.get(i); if(ranges == null) fkeys.add(new Key().withHashKeyElement(new AttributeValue().withS(key))); else fkeys.add(new Key().withHashKeyElement(new AttributeValue().withS(key)) .withRangeKeyElement(new AttributeValue().withS(ranges.get(i).toString()))); } requestItems.put(tableName, new KeysAndAttributes().withKeys(fkeys)); BatchGetItemRequest batchGetItemRequest = new BatchGetItemRequest().withRequestItems(requestItems); BatchGetItemResult result = client.batchGetItem(batchGetItemRequest);
Wszelkie wskazówki?
mógłbyś dodać swoją (ewentualnie skondensowany) schemat i fragment kodu wykonujący zapytanie do złagodzenia analiza? Dzięki! –
Zmieniono pytanie, aby je uwzględnić. Dzięki! –
Masz "if (ranges == null)", ale jeśli tabela ma klawisz zakresu, wymagana jest wartość; nie można tego pominąć. –