DynamoDB - การสร้างรายการ
การสร้างไอเท็มใน DynamoDB ประกอบด้วยข้อมูลจำเพาะไอเท็มและแอ็ตทริบิวต์เป็นหลักและอ็อพชันในการระบุเงื่อนไข แต่ละรายการมีอยู่เป็นชุดของแอตทริบิวต์โดยแต่ละแอตทริบิวต์ตั้งชื่อและกำหนดค่าของประเภทหนึ่ง ๆ
ประเภทค่า ได้แก่ สเกลาร์เอกสารหรือชุด รายการมีขีด จำกัด ขนาด 400KB โดยมีจำนวนแอตทริบิวต์ใด ๆ ที่สามารถปรับให้เหมาะสมได้ภายในขีด จำกัด นั้น ขนาดชื่อและค่า (ความยาวไบนารีและ UTF-8) กำหนดขนาดรายการ การใช้ชื่อแอตทริบิวต์แบบสั้นช่วยในการย่อขนาดรายการ
Note- คุณต้องระบุแอตทริบิวต์คีย์หลักทั้งหมดโดยคีย์หลักต้องใช้คีย์พาร์ติชันเท่านั้น และคีย์คอมโพสิตที่ต้องใช้ทั้งพาร์ติชันและคีย์การเรียงลำดับ
นอกจากนี้ตารางจำไม่มีสคีมาที่กำหนดไว้ล่วงหน้า คุณสามารถจัดเก็บชุดข้อมูลที่แตกต่างกันอย่างมากในตารางเดียว
ใช้คอนโซล GUI, Java หรือเครื่องมืออื่นเพื่อทำงานนี้
จะสร้างรายการโดยใช้ GUI Console ได้อย่างไร?
ไปที่คอนโซล ในบานหน้าต่างนำทางทางด้านซ้ายให้เลือกTables. เลือกชื่อตารางเพื่อใช้เป็นปลายทางจากนั้นเลือกไฟล์Items ตามที่แสดงในภาพหน้าจอต่อไปนี้
เลือก Create Item. หน้าจอ Create Item มีอินเทอร์เฟซสำหรับป้อนค่าแอ็ตทริบิวต์ที่ต้องการ ต้องป้อนดัชนีรองด้วย
หากคุณต้องการแอตทริบิวต์เพิ่มเติมให้เลือกเมนูการทำงานทางด้านซ้ายของไฟล์ Message. จากนั้นเลือกAppendและประเภทข้อมูลที่ต้องการ
หลังจากป้อนข้อมูลที่จำเป็นทั้งหมดแล้วให้เลือก Save เพื่อเพิ่มรายการ
วิธีใช้ Java ในการสร้างรายการ
การใช้ Java ในการดำเนินการสร้างไอเท็มประกอบด้วยการสร้างอินสแตนซ์คลาส DynamoDB อินสแตนซ์คลาสตารางอินสแตนซ์คลาสไอเท็มและการระบุคีย์หลักและแอ็ตทริบิวต์ของไอเท็มที่คุณจะสร้าง จากนั้นเพิ่มรายการใหม่ของคุณด้วยเมธอด putItem
ตัวอย่าง
DynamoDB dynamoDB = new DynamoDB (new AmazonDynamoDBClient(
new ProfileCredentialsProvider()));
Table table = dynamoDB.getTable("ProductList");
// Spawn a related items list
List<Number> RELItems = new ArrayList<Number>();
RELItems.add(123);
RELItems.add(456);
RELItems.add(789);
//Spawn a product picture map
Map<String, String> photos = new HashMap<String, String>();
photos.put("Anterior", "http://xyz.com/products/101_front.jpg");
photos.put("Posterior", "http://xyz.com/products/101_back.jpg");
photos.put("Lateral", "http://xyz.com/products/101_LFTside.jpg");
//Spawn a product review map
Map<String, List<String>> prodReviews = new HashMap<String, List<String>>();
List<String> fiveStarRVW = new ArrayList<String>();
fiveStarRVW.add("Shocking high performance.");
fiveStarRVW.add("Unparalleled in its market.");
prodReviews.put("5 Star", fiveStarRVW);
List<String> oneStarRVW = new ArrayList<String>();
oneStarRVW.add("The worst offering in its market.");
prodReviews.put("1 Star", oneStarRVW);
// Generate the item
Item item = new Item()
.withPrimaryKey("Id", 101)
.withString("Nomenclature", "PolyBlaster 101")
.withString("Description", "101 description")
.withString("Category", "Hybrid Power Polymer Cutter")
.withString("Make", "Brand – XYZ")
.withNumber("Price", 50000)
.withString("ProductCategory", "Laser Cutter")
.withBoolean("Availability", true)
.withNull("Qty")
.withList("ItemsRelated", RELItems)
.withMap("Images", photos)
.withMap("Reviews", prodReviews);
// Add item to the table
PutItemOutcome outcome = table.putItem(item);
คุณยังสามารถดูตัวอย่างขนาดใหญ่ต่อไปนี้
Note- ตัวอย่างต่อไปนี้อาจถือว่าเป็นแหล่งข้อมูลที่สร้างขึ้นก่อนหน้านี้ ก่อนที่จะพยายามดำเนินการให้จัดหาไลบรารีที่สนับสนุนและสร้างแหล่งข้อมูลที่จำเป็น (ตารางที่มีคุณสมบัติที่ต้องการหรือแหล่งอ้างอิงอื่น ๆ )
ตัวอย่างต่อไปนี้ยังใช้ Eclipse IDE, ไฟล์ข้อมูลรับรอง AWS และ AWS Toolkit ภายใน Eclipse AWS Java Project
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 CreateItemOpSample {
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());
}
}
}