DynamoDB - Membuat Item
Membuat item di DynamoDB terutama terdiri dari spesifikasi item dan atribut, dan opsi untuk menentukan kondisi. Setiap item ada sebagai satu set atribut, dengan setiap atribut diberi nama dan diberi nilai dari tipe tertentu.
Jenis nilai termasuk skalar, dokumen, atau set. Item memiliki batas ukuran 400KB, dengan kemungkinan sejumlah atribut yang dapat dipasang dalam batas itu. Ukuran nama dan nilai (panjang biner dan UTF-8) menentukan ukuran item. Menggunakan bantuan nama atribut pendek dalam meminimalkan ukuran item.
Note- Anda harus menentukan semua atribut kunci utama, dengan kunci utama hanya memerlukan kunci partisi; dan kunci komposit yang membutuhkan partisi dan kunci sortir.
Juga, ingat tabel tidak memiliki skema yang ditentukan sebelumnya. Anda dapat menyimpan kumpulan data yang sangat berbeda dalam satu tabel.
Gunakan konsol GUI, Java, atau alat lain untuk melakukan tugas ini.
Bagaimana Cara Membuat Item Menggunakan GUI Console?
Arahkan ke konsol. Di panel navigasi di sisi kiri, pilihTables. Pilih nama tabel untuk digunakan sebagai tujuan, lalu pilihItems tab seperti yang ditunjukkan pada tangkapan layar berikut.
Pilih Create Item. Layar Buat Item menyediakan antarmuka untuk memasukkan nilai atribut yang diperlukan. Indeks sekunder apa pun juga harus dimasukkan.
Jika Anda memerlukan lebih banyak atribut, pilih menu tindakan di sebelah kiri Message. Lalu pilihAppend, dan tipe data yang diinginkan.
Setelah memasukkan semua informasi penting, pilih Save untuk menambahkan item.
Bagaimana Cara Menggunakan Java dalam Pembuatan Item?
Menggunakan Java dalam operasi pembuatan item terdiri dari pembuatan instance kelas DynamoDB, instance kelas Tabel, instance kelas Item, dan menentukan kunci utama dan atribut dari item yang akan Anda buat. Kemudian tambahkan item baru Anda dengan metode putItem.
Contoh
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);
Anda juga dapat melihat contoh yang lebih besar berikut ini.
Note- Contoh berikut mungkin menganggap sumber data yang dibuat sebelumnya. Sebelum mencoba untuk mengeksekusi, dapatkan pustaka pendukung dan buat sumber data yang diperlukan (tabel dengan karakteristik yang diperlukan, atau sumber referensi lainnya).
Contoh berikut juga menggunakan Eclipse IDE, file kredensial AWS, dan AWS Toolkit dalam Proyek Java Eclipse AWS.
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());
}
}
}