DynamoDB - आइटम हटाएं

डायनमोबी में एक आइटम को हटाने के लिए केवल टेबल नाम और आइटम कुंजी प्रदान करने की आवश्यकता होती है। सशर्त अभिव्यक्ति का उपयोग करने के लिए भी दृढ़ता से सिफारिश की जाती है जो गलत वस्तुओं को हटाने से बचने के लिए आवश्यक होगा।

हमेशा की तरह, आप इस कार्य को करने के लिए GUI कंसोल, जावा या किसी अन्य आवश्यक उपकरण का उपयोग कर सकते हैं।

GUI कंसोल का उपयोग करके आइटम हटाएं

कंसोल पर नेविगेट करें। बाईं ओर नेविगेशन फलक में, का चयन करेंTables। फिर तालिका नाम का चयन करें, औरItems टैब।

हटाने के लिए वांछित आइटम चुनें, और चुनें Actions | Delete

Delete Item(s)डायलॉग बॉक्स तब दिखाई देता है जैसा कि निम्नलिखित स्क्रू में दिखाया गया है। पुष्टि करने के लिए "हटाएं" चुनें।

जावा का उपयोग करके आइटम कैसे हटाएं?

आइटम हटाने के कार्यों में जावा का उपयोग करने से केवल डायनमोबी क्लाइंट उदाहरण बनाना और कॉल करना शामिल है deleteItem आइटम की कुंजी का उपयोग करके विधि।

आप निम्नलिखित उदाहरण देख सकते हैं, जहां इसे विस्तार से समझाया गया है।

DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient( 
   new ProfileCredentialsProvider()));
   
Table table = dynamoDB.getTable("ProductList");
DeleteItemOutcome outcome = table.deleteItem("IDnum", 151);

आप गलत विलोपन से बचाने के लिए पैरामीटर भी निर्दिष्ट कर सकते हैं। बस एक का उपयोग करेंConditionExpression

उदाहरण के लिए -

Map<String,Object> expressionAttributeValues = new HashMap<String,Object>(); 
expressionAttributeValues.put(":val", false);
  
DeleteItemOutcome outcome = table.deleteItem("IDnum",151, 
   "Ship = :val",  
   null,                   // doesn't use 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 DeleteItemOpSample {  
   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 deleteItem() {  
      Table table = dynamoDB.getTable(tableName);  
      try {  
         DeleteItemSpec deleteItemSpec = new DeleteItemSpec() 
            .withPrimaryKey("ID", 303)  
            .withConditionExpression("#ip = :val") 
            .withNameMap(new NameMap() 
            .with("#ip", "InProduction"))
            .withValueMap(new ValueMap() 
            .withBoolean(":val", false)) 
            .withReturnValues(ReturnValue.ALL_OLD);  
         DeleteItemOutcome outcome = table.deleteItem(deleteItemSpec);  
         
         // Confirm 
         System.out.println("Displaying deleted item..."); 
         System.out.println(outcome.getItem().toJSONPretty());  
      } catch (Exception e) { 
         System.err.println("Cannot delete item in " + tableName); 
         System.err.println(e.getMessage()); 
      } 
   } 
}