📜  DynamoDB-查询表

📅  最后修改于: 2020-11-28 13:56:43             🧑  作者: Mango


查询表主要需要选择一个表,指定一个分区键并执行查询。以及使用二级索引和通过扫描操作执行更深层过滤的选项。

利用GUI控制台,Java或其他选项来执行任务。

使用GUI控制台查询表

使用先前创建的表执行一些简单的查询。首先,通过以下网址打开控制台: https://console.aws.amazon.com/dynamodb

从导航窗格中选择,然后从表列表中选择答复。然后选择项目选项卡以查看加载的数据。

选择“创建项目”按钮下方的数据过滤链接(“扫描:[表]回复”)。

使用GUI控制台查询表

在过滤屏幕中,选择查询作为操作。输入适当的分区键值,然后单击开始

然后, Reply表返回匹配的项目。

回复表

使用Java查询表

使用Java中的查询方法来执行数据检索操作。它需要指定分区键值,而排序键是可选的。

首先创建一个描述参数的querySpec对象,对Java查询进行编码。然后将对象传递给查询方法。我们使用前面示例中的分区键。

您可以查看以下示例-

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 nameMap = new HashMap(); 
      nameMap.put("#ID", "ID");  
      HashMap valueMap = new HashMap(); 
      valueMap.put(":xxx", 122);
      QuerySpec querySpec = new QuerySpec() 
         .withKeyConditionExpression("#ID = :xxx") 
         .withNameMap(new NameMap().with("#ID", "ID")) 
         .withValueMap(valueMap);  
      
      ItemCollection items = null; 
      Iterator 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()); 
      } 
   } 
}

请注意,查询使用分区键,但是,辅助索引为查询提供了另一个选项。它们的灵活性允许查询非关键属性,这个主题将在本教程的后面部分讨论。

扫描方法还通过收集所有表数据来支持检索操作。可选的.withFilterExpression防止超出指定条件的项目出现在结果中。

在本教程的后面,我们将详细讨论扫描。现在,看看以下示例-

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 items = table.scan(scanSpec);  
         Iterator 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()); 
      } 
   } 
}