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()); 
      } 
   } 
}