DynamoDB-쿼리 테이블

테이블을 쿼리하려면 주로 테이블을 선택하고 파티션 키를 지정하고 쿼리를 실행해야합니다. 보조 인덱스를 사용하고 스캔 작업을 통해 더 깊은 필터링을 수행하는 옵션이 있습니다.

GUI 콘솔, Java 또는 다른 옵션을 사용하여 작업을 수행합니다.

GUI 콘솔을 사용하여 테이블 쿼리

이전에 만든 테이블을 사용하여 몇 가지 간단한 쿼리를 수행합니다. 먼저 콘솔을 엽니 다.https://console.aws.amazon.com/dynamodb

고르다 Tables 탐색 창에서 Reply테이블 목록에서. 그런 다음Items 로드 된 데이터를 보려면 탭을 클릭하십시오.

아래의 데이터 필터링 링크 ( "스캔 : [표] 응답")를 선택합니다. Create Item 단추.

필터링 화면에서 작업에 대한 쿼리를 선택합니다. 적절한 파티션 키 값을 입력하고Start.

그만큼 Reply 그런 다음 테이블은 일치하는 항목을 반환합니다.

Java를 사용한 쿼리 테이블

Java의 쿼리 메소드를 사용하여 데이터 검색 작업을 수행합니다. 선택적으로 정렬 키를 사용하여 파티션 키 값을 지정해야합니다.

먼저 다음을 생성하여 Java 쿼리를 코딩합니다. querySpec object매개 변수 설명. 그런 다음 개체를 쿼리 메서드에 전달합니다. 이전 예제의 파티션 키를 사용합니다.

다음 예를 검토 할 수 있습니다.

import java.util.HashMap;
import java.util.Iterator;

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.QueryOutcome;
import com.amazonaws.services.dynamodbv2.document.Table;
import com.amazonaws.services.dynamodbv2.document.spec.QuerySpec;
import com.amazonaws.services.dynamodbv2.document.utils.NameMap;

public class ProductsQuery {  
   public static void main(String[] args) throws Exception {  
      AmazonDynamoDBClient client = new AmazonDynamoDBClient() 
         .withEndpoint("http://localhost:8000");  
      
      DynamoDB dynamoDB = new DynamoDB(client);  
      Table table = dynamoDB.getTable("Products");  
      HashMap<String, String> nameMap = new HashMap<String, String>(); 
      nameMap.put("#ID", "ID");  
      HashMap<String, Object> valueMap = new HashMap<String, Object>(); 
      valueMap.put(":xxx", 122);
      QuerySpec querySpec = new QuerySpec() 
         .withKeyConditionExpression("#ID = :xxx") 
         .withNameMap(new NameMap().with("#ID", "ID")) 
         .withValueMap(valueMap);  
      
      ItemCollection<QueryOutcome> items = null; 
      Iterator<Item> iterator = null; 
      Item item = null;  
      try { 
         System.out.println("Product with the ID 122"); 
         items = table.query(querySpec);  
         iterator = items.iterator(); 
         
         while (iterator.hasNext()) { 
            item = iterator.next(); 
            System.out.println(item.getNumber("ID") + ": " 
               + item.getString("Nomenclature")); 
         } 
      } catch (Exception e) { 
         System.err.println("Cannot find products with the ID number 122"); 
         System.err.println(e.getMessage()); 
      } 
   } 
}

쿼리는 파티션 키를 사용하지만 보조 인덱스는 쿼리에 대한 또 다른 옵션을 제공합니다. 이러한 유연성을 통해이 자습서의 뒷부분에서 설명 할 주제 인 키가 아닌 속성을 쿼리 할 수 ​​있습니다.

스캔 방법은 또한 모든 테이블 데이터를 수집하여 검색 작업을 지원합니다. 그만큼optional .withFilterExpression 지정된 기준을 벗어난 항목이 결과에 나타나지 않도록합니다.

이 튜토리얼의 뒷부분에서 scanning상세히. 이제 다음 예제를 살펴보십시오.

import java.util.Iterator;

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.ScanOutcome;
import com.amazonaws.services.dynamodbv2.document.Table;
import com.amazonaws.services.dynamodbv2.document.spec.ScanSpec;
import com.amazonaws.services.dynamodbv2.document.utils.NameMap;
import com.amazonaws.services.dynamodbv2.document.utils.ValueMap;

public class ProductsScan {  
   public static void main(String[] args) throws Exception {  
      AmazonDynamoDBClient client = new AmazonDynamoDBClient() 
         .withEndpoint("http://localhost:8000");  
      
      DynamoDB dynamoDB = new DynamoDB(client);  
      Table table = dynamoDB.getTable("Products");  
      ScanSpec scanSpec = new ScanSpec() 
         .withProjectionExpression("#ID, Nomenclature , stat.sales") 
         .withFilterExpression("#ID between :start_id and :end_id") 
         .withNameMap(new NameMap().with("#ID",  "ID")) 
         .withValueMap(new ValueMap().withNumber(":start_id", 120)
         .withNumber(":end_id", 129));  
      
      try { 
         ItemCollection<ScanOutcome> items = table.scan(scanSpec);  
         Iterator<Item> iter = items.iterator(); 
        
         while (iter.hasNext()) {
            Item item = iter.next(); 
            System.out.println(item.toString()); 
         } 
      } catch (Exception e) { 
         System.err.println("Cannot perform a table scan:"); 
         System.err.println(e.getMessage()); 
      } 
   } 
}