डायनॉम्बडी - क्वेरी
क्वेरी प्राथमिक कुंजी के माध्यम से आइटम या माध्यमिक सूचकांकों का पता लगाती हैं। एक क्वेरी करने के लिए एक विभाजन कुंजी और विशिष्ट मूल्य, या एक सॉर्ट कुंजी और मूल्य की आवश्यकता होती है; तुलना के साथ फ़िल्टर करने के विकल्प के साथ। किसी क्वेरी के डिफ़ॉल्ट व्यवहार में दिए गए प्राथमिक कुंजी के साथ जुड़ी वस्तुओं के लिए हर विशेषता को वापस करना शामिल है। हालाँकि, आप इच्छित विशेषताओं को निर्दिष्ट कर सकते हैंProjectionExpression पैरामीटर।
एक क्वेरी का उपयोग करता है KeyConditionExpressionआइटम का चयन करने के लिए पैरामीटर, जिसमें समानता की स्थिति के रूप में विभाजन कुंजी नाम और मूल्य प्रदान करने की आवश्यकता होती है। आपके पास मौजूद किसी भी प्रकार की कुंजी के लिए एक अतिरिक्त शर्त प्रदान करने का विकल्प है।
सॉर्ट की प्रमुख शर्तों के कुछ उदाहरण हैं -
अनु क्रमांक | स्थिति का वर्णन |
---|---|
1 | x = y यदि गुण x बराबर y है तो यह सत्य का मूल्यांकन करता है। |
2 | x < y यदि x से y कम है तो यह सत्य का मूल्यांकन करता है। |
3 | x <= y यदि x से y के बराबर या उससे कम है तो यह सत्य का मूल्यांकन करता है। |
4 | x > y यदि x से y अधिक है तो यह सत्य का मूल्यांकन करता है। |
5 | x >= y यह सच है कि अगर x, y से अधिक या बराबर है, तो इसका मूल्यांकन करता है। |
6 | x BETWEEN y AND z यदि x => y, और <= z दोनों है तो यह सत्य का मूल्यांकन करता है। |
DynamoDB भी निम्नलिखित कार्यों का समर्थन करता है: begins_with (x, substr)
यह सच है कि अगर एक्स निर्दिष्ट स्ट्रिंग के साथ शुरू होता है मूल्यांकन करता है।
निम्नलिखित शर्तों को कुछ आवश्यकताओं के अनुरूप होना चाहिए -
गुण नाम az या AZ सेट के भीतर एक चरित्र के साथ शुरू होना चाहिए।
विशेषता नाम का दूसरा वर्ण az, AZ या 0-9 सेट में आना चाहिए।
गुण नाम आरक्षित शब्दों का उपयोग नहीं कर सकते।
ऊपर दिए गए अवरोधों के अनुपालन से बाहर के नामों को एक प्लेसहोल्डर परिभाषित कर सकते हैं।
सॉर्ट कुंजी क्रम में पुनर्प्राप्ति को निष्पादित करके और वर्तमान में मौजूद किसी भी स्थिति और फ़िल्टर अभिव्यक्ति का उपयोग करके क्वेरी की प्रक्रिया। प्रश्न हमेशा एक परिणाम सेट लौटाते हैं, और कोई मिलान नहीं होने पर, यह एक खाली रिटर्न देता है।
परिणाम हमेशा क्रमबद्ध कुंजी क्रम में लौटते हैं, और आरोही क्रम के रूप में परिवर्तनीय डिफ़ॉल्ट के साथ डेटा प्रकार आधारित आदेश।
जावा के साथ क्वेरी करना
जावा में क्वेरी आपको टेबल और सेकेंडरी इंडेक्स को क्वेरी करने की अनुमति देती है। उन्हें सॉर्ट कुंजी और शर्तों को निर्दिष्ट करने के विकल्प के साथ विभाजन कुंजी और समानता की शर्तों के विनिर्देश की आवश्यकता होती है।
जावा में एक क्वेरी के लिए सामान्य आवश्यक कदमों में डायनामोडीबी श्रेणी का उदाहरण बनाना, लक्ष्य तालिका के लिए तालिका वर्ग आवृत्ति, और क्वेरी वस्तु प्राप्त करने के लिए तालिका उदाहरण की क्वेरी विधि को शामिल करना शामिल है।
क्वेरी की प्रतिक्रिया में ए शामिल है 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- निम्न प्रोग्राम पहले से बनाए गए डेटा स्रोत को मान सकता है। निष्पादित करने का प्रयास करने से पहले, सहायक पुस्तकालयों का अधिग्रहण करें और आवश्यक डेटा स्रोत बनाएं (आवश्यक विशेषताओं के साथ टेबल, या अन्य संदर्भित स्रोत)।
यह उदाहरण ग्रहण आईडीई, एक एडब्ल्यूएस क्रेडेंशियल फ़ाइल और एडब्ल्यूएस टूलकिट को एक्लिप्स एईए जावा प्रोजेक्ट के भीतर भी उपयोग करता है।
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());
}
}
}