DynamoDB - अपडेट आइटम
डायनमोबी में एक आइटम को अपडेट करना मुख्य रूप से आइटम के लिए पूर्ण प्राथमिक कुंजी और तालिका नाम निर्दिष्ट करना है। इसमें आपके द्वारा संशोधित प्रत्येक विशेषता के लिए एक नए मूल्य की आवश्यकता होती है। ऑपरेशन का उपयोग करता हैUpdateItem, जो मौजूदा वस्तुओं को संशोधित करता है या लापता वस्तु की खोज पर बनाता है।
अद्यतनों में, आप परिचालन से पहले और बाद में मूल और नए मूल्यों को प्रदर्शित करके परिवर्तनों को ट्रैक करना चाह सकते हैं। UpdateItem का उपयोग करता हैReturnValues इसे प्राप्त करने के लिए पैरामीटर।
Note - ऑपरेशन क्षमता इकाई की खपत की रिपोर्ट नहीं करता है, लेकिन आप इसका उपयोग कर सकते हैं ReturnConsumedCapacity पैरामीटर।
इस कार्य को करने के लिए GUI कंसोल, जावा या किसी अन्य टूल का उपयोग करें।
GUI टूल्स का उपयोग करके आइटम कैसे अपडेट करें?
कंसोल पर नेविगेट करें। बाईं ओर नेविगेशन फलक में, का चयन करेंTables। आवश्यक तालिका चुनें, और तब चुनेंItems टैब।
किसी अद्यतन के लिए वांछित आइटम चुनें, और चुनें Actions | Edit।
में आवश्यक किसी भी विशेषता या मूल्यों को संशोधित करें Edit Item खिड़की।
जावा का उपयोग करके आइटम अपडेट करें
आइटम अद्यतन परिचालनों में जावा का उपयोग करने के लिए एक टेबल क्लास उदाहरण बनाने और उसके कॉल करने की आवश्यकता होती है updateItemतरीका। तब आप आइटम की प्राथमिक कुंजी निर्दिष्ट करते हैं, और एक प्रदान करते हैंUpdateExpression विवरण विशेषताओं में संशोधन।
निम्नलिखित उसी का एक उदाहरण है -
DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient(
new ProfileCredentialsProvider()));
Table table = dynamoDB.getTable("ProductList");
Map<String, String> expressionAttributeNames = new HashMap<String, String>();
expressionAttributeNames.put("#M", "Make");
expressionAttributeNames.put("#P", "Price
expressionAttributeNames.put("#N", "ID");
Map<String, Object> expressionAttributeValues = new HashMap<String, Object>();
expressionAttributeValues.put(":val1",
new HashSet<String>(Arrays.asList("Make1","Make2")));
expressionAttributeValues.put(":val2", 1); //Price
UpdateItemOutcome outcome = table.updateItem(
"internalID", // key attribute name
111, // key attribute value
"add #M :val1 set #P = #P - :val2 remove #N", // UpdateExpression
expressionAttributeNames,
expressionAttributeValues);
updateItem विधि शर्तों को निर्दिष्ट करने की भी अनुमति देती है, जिसे निम्नलिखित उदाहरण में देखा जा सकता है -
Table table = dynamoDB.getTable("ProductList");
Map<String, String> expressionAttributeNames = new HashMap<String, String>();
expressionAttributeNames.put("#P", "Price");
Map<String, Object> expressionAttributeValues = new HashMap<String, Object>();
expressionAttributeValues.put(":val1", 44); // change Price to 44
expressionAttributeValues.put(":val2", 15); // only if currently 15
UpdateItemOutcome outcome = table.updateItem (new PrimaryKey("internalID",111),
"set #P = :val1", // Update
"#P = :val2", // Condition
expressionAttributeNames,
expressionAttributeValues);
काउंटरों का उपयोग करके आइटम अपडेट करें
डायनॉम्बिक परमाणु काउंटरों की अनुमति देता है, जिसका अर्थ है कि अन्य अनुरोधों को प्रभावित किए बिना इनटर्मेंट / इंक्रीमेंट विशेषता मानों को अपडेट करना; इसके अलावा, काउंटर हमेशा अद्यतन करते हैं।
निम्नलिखित एक उदाहरण है जो बताता है कि यह कैसे किया जा सकता है।
Note- निम्नलिखित नमूना पहले से निर्मित डेटा स्रोत मान सकते हैं। निष्पादित करने का प्रयास करने से पहले, सहायक पुस्तकालयों का अधिग्रहण करें और आवश्यक डेटा स्रोत बनाएं (आवश्यक विशेषताओं के साथ तालिकाओं, या अन्य संदर्भित स्रोत)।
यह नमूना ग्रहण आईडीई, एक एडब्ल्यूएस क्रेडेंशियल फ़ाइल और एडब्ल्यूएस टूलकिट को एक्लिप्स एईए जावा प्रोजेक्ट के भीतर भी उपयोग करता है।
package com.amazonaws.codesamples.document;
import java.io.IOException;
import java.util.Arrays;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DeleteItemOutcome;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.Table;
import com.amazonaws.services.dynamodbv2.document.UpdateItemOutcome;
import com.amazonaws.services.dynamodbv2.document.spec.DeleteItemSpec;
import com.amazonaws.services.dynamodbv2.document.spec.UpdateItemSpec;
import com.amazonaws.services.dynamodbv2.document.utils.NameMap;
import com.amazonaws.services.dynamodbv2.document.utils.ValueMap;
import com.amazonaws.services.dynamodbv2.model.ReturnValue;
public class UpdateItemOpSample {
static DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient(
new ProfileCredentialsProvider()));
static String tblName = "ProductList";
public static void main(String[] args) throws IOException {
createItems();
retrieveItem();
// Execute updates
updateMultipleAttributes();
updateAddNewAttribute();
updateExistingAttributeConditionally();
// Item deletion
deleteItem();
}
private static void createItems() {
Table table = dynamoDB.getTable(tblName);
try {
Item item = new Item()
.withPrimaryKey("ID", 303)
.withString("Nomenclature", "Polymer Blaster 4000")
.withStringSet( "Manufacturers",
new HashSet<String>(Arrays.asList("XYZ Inc.", "LMNOP Inc.")))
.withNumber("Price", 50000)
.withBoolean("InProduction", true)
.withString("Category", "Laser Cutter");
table.putItem(item);
item = new Item()
.withPrimaryKey("ID", 313)
.withString("Nomenclature", "Agitatatron 2000")
.withStringSet( "Manufacturers",
new HashSet<String>(Arrays.asList("XYZ Inc,", "CDE Inc.")))
.withNumber("Price", 40000)
.withBoolean("InProduction", true)
.withString("Category", "Agitator");
table.putItem(item);
} catch (Exception e) {
System.err.println("Cannot create items.");
System.err.println(e.getMessage());
}
}
private static void updateAddNewAttribute() {
Table table = dynamoDB.getTable(tableName);
try {
Map<String, String> expressionAttributeNames = new HashMap<String, String>();
expressionAttributeNames.put("#na", "NewAttribute");
UpdateItemSpec updateItemSpec = new UpdateItemSpec()
.withPrimaryKey("ID", 303)
.withUpdateExpression("set #na = :val1")
.withNameMap(new NameMap()
.with("#na", "NewAttribute"))
.withValueMap(new ValueMap()
.withString(":val1", "A value"))
.withReturnValues(ReturnValue.ALL_NEW);
UpdateItemOutcome outcome = table.updateItem(updateItemSpec);
// Confirm
System.out.println("Displaying updated item...");
System.out.println(outcome.getItem().toJSONPretty());
} catch (Exception e) {
System.err.println("Cannot add an attribute in " + tableName);
System.err.println(e.getMessage());
}
}
}