DynamoDB - Запросы
Запросы обнаруживают элементы или вторичные индексы с помощью первичных ключей. Для выполнения запроса требуется ключ раздела и определенное значение или ключ сортировки и значение; с возможностью фильтрации сравнений. Поведение запроса по умолчанию состоит в возврате каждого атрибута для элементов, связанных с предоставленным первичным ключом. Однако вы можете указать желаемые атрибуты с помощьюProjectionExpression параметр.
Запрос использует KeyConditionExpressionпараметры для выбора элементов, для чего требуется указать имя и значение ключа раздела в форме условия равенства. У вас также есть возможность указать дополнительное условие для любых имеющихся ключей сортировки.
Вот несколько примеров ключевых условий сортировки:
Старший Нет | Состояние и описание |
---|---|
1 | x = y Он принимает значение true, если атрибут x равен y. |
2 | x < y Он принимает значение true, если x меньше y. |
3 | x <= y Он принимает значение true, если x меньше или равно y. |
4 | x > y Он принимает значение true, если x больше y. |
5 | x >= y Он принимает значение true, если x больше или равно y. |
6 | x BETWEEN y AND z Он принимает значение true, если x одновременно равно> = y и <= z. |
DynamoDB также поддерживает следующие функции: begins_with (x, substr)
Он принимает значение true, если атрибут x начинается с указанной строки.
Следующие условия должны соответствовать определенным требованиям -
Имена атрибутов должны начинаться с символа из набора az или AZ.
Второй символ имени атрибута должен входить в набор az, AZ или 0-9.
В именах атрибутов нельзя использовать зарезервированные слова.
Имена атрибутов, не соответствующие указанным выше ограничениям, могут определять заполнитель.
Запрос обрабатывает, выполняя извлечения в порядке ключей сортировки и используя любые имеющиеся условия и выражения фильтра. Запросы всегда возвращают набор результатов, а при отсутствии совпадений - пустой.
Результаты всегда возвращаются в порядке ключей сортировки и в порядке на основе типа данных с изменяемым значением по умолчанию в порядке возрастания.
Запросы с помощью Java
Запросы в Java позволяют запрашивать таблицы и вторичные индексы. Они требуют указания ключей раздела и условий равенства с возможностью указания ключей и условий сортировки.
Общие необходимые шаги для запроса в Java включают создание экземпляра класса DynamoDB, экземпляра класса Table для целевой таблицы и вызов метода запроса экземпляра Table для получения объекта запроса.
Ответ на запрос содержит ItemCollection объект, предоставляющий все возвращенные товары.
В следующем примере демонстрируется подробный запрос -
DynamoDB dynamoDB = new DynamoDB (
new AmazonDynamoDBClient(new ProfileCredentialsProvider()));
Table table = dynamoDB.getTable("Response");
QuerySpec spec = new QuerySpec()
.withKeyConditionExpression("ID = :nn")
.withValueMap(new ValueMap()
.withString(":nn", "Product Line 1#P1 Thread 1"));
ItemCollection<QueryOutcome> items = table.query(spec);
Iterator<Item> iterator = items.iterator();
Item item = null;
while (iterator.hasNext()) {
item = iterator.next();
System.out.println(item.toJSONPretty());
}
Метод запроса поддерживает большое количество дополнительных параметров. В следующем примере показано, как использовать эти параметры -
Table table = dynamoDB.getTable("Response");
QuerySpec spec = new QuerySpec()
.withKeyConditionExpression("ID = :nn and ResponseTM > :nn_responseTM")
.withFilterExpression("Author = :nn_author")
.withValueMap(new ValueMap()
.withString(":nn", "Product Line 1#P1 Thread 1")
.withString(":nn_responseTM", twoWeeksAgoStr)
.withString(":nn_author", "Member 123"))
.withConsistentRead(true);
ItemCollection<QueryOutcome> items = table.query(spec);
Iterator<Item> iterator = items.iterator();
while (iterator.hasNext()) {
System.out.println(iterator.next().toJSONPretty());
}
Вы также можете просмотреть следующий более крупный пример.
Note- Следующая программа может предполагать ранее созданный источник данных. Перед попыткой выполнения приобретите вспомогательные библиотеки и создайте необходимые источники данных (таблицы с требуемыми характеристиками или другие источники, на которые есть ссылки).
В этом примере также используется Eclipse IDE, файл учетных данных AWS и AWS Toolkit в рамках проекта Eclipse AWS Java.
package com.amazonaws.codesamples.document;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Iterator;
import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.ItemCollection;
import com.amazonaws.services.dynamodbv2.document.Page;
import com.amazonaws.services.dynamodbv2.document.QueryOutcome;
import com.amazonaws.services.dynamodbv2.document.Table;
import com.amazonaws.services.dynamodbv2.document.spec.QuerySpec;
import com.amazonaws.services.dynamodbv2.document.utils.ValueMap;
public class QueryOpSample {
static DynamoDB dynamoDB = new DynamoDB(
new AmazonDynamoDBClient(new ProfileCredentialsProvider()));
static String tableName = "Reply";
public static void main(String[] args) throws Exception {
String forumName = "PolyBlaster";
String threadSubject = "PolyBlaster Thread 1";
getThreadReplies(forumName, threadSubject);
}
private static void getThreadReplies(String forumName, String threadSubject) {
Table table = dynamoDB.getTable(tableName);
String replyId = forumName + "#" + threadSubject;
QuerySpec spec = new QuerySpec()
.withKeyConditionExpression("Id = :v_id")
.withValueMap(new ValueMap()
.withString(":v_id", replyId));
ItemCollection<QueryOutcome> items = table.query(spec);
System.out.println("\ngetThreadReplies results:");
Iterator<Item> iterator = items.iterator();
while (iterator.hasNext()) {
System.out.println(iterator.next().toJSONPretty());
}
}
}