डायनमोडीबी - क्वेरी तालिका

मुख्य रूप से तालिका का चयन करने के लिए एक तालिका का चयन करने की आवश्यकता होती है, एक विभाजन कुंजी निर्दिष्ट करता है, और क्वेरी निष्पादित करता है; सेकंडरी इंडेक्स का उपयोग करने और स्कैन संचालन के माध्यम से गहरी छानने के विकल्पों के साथ।

कार्य करने के लिए GUI कंसोल, जावा या किसी अन्य विकल्प का उपयोग करें।

GUI कंसोल का उपयोग करके क्वेरी तालिका

पहले से बनाई गई तालिकाओं का उपयोग करके कुछ सरल क्वेरी करें। सबसे पहले, कंसोल को खोलेंhttps://console.aws.amazon.com/dynamodb

चुनें Tables नेविगेशन फलक से और चुनें Replyतालिका सूची से। फिर का चयन करेंItems लोड किए गए डेटा को देखने के लिए टैब।

नीचे डेटा फ़िल्टरिंग लिंक ("स्कैन: [टेबल] उत्तर") का चयन करें Create Item बटन।

फ़िल्टरिंग स्क्रीन में, ऑपरेशन के लिए क्वेरी का चयन करें। उचित विभाजन कुंजी मान दर्ज करें, और क्लिक करेंStart

Reply तालिका फिर मिलान आइटम लौटाती है।

जावा का उपयोग करके क्वेरी तालिका

डेटा पुनर्प्राप्ति ऑपरेशन करने के लिए जावा में क्वेरी विधि का उपयोग करें। इसे वैकल्पिक के रूप में कुंजी के साथ विभाजन कुंजी मान निर्दिष्ट करने की आवश्यकता है।

पहले एक जावा क्वैरी बनाकर कोड बनाएं 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()); 
      } 
   } 
}