Version AWS SDK for Java 1.x wurde am 31. Juli 2024 in den Wartungsmodus versetzt und wird end-of-support
Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.
Arbeiten mit Tabellen in DynamoDB
Tabellen sind Container für alle Elemente in einer DynamoDB-Datenbank. Bevor Sie Daten zu DynamoDB hinzufügen oder daraus entfernen können, müssen Sie eine Tabelle erstellen.
Für jede Tabelle definieren Sie:
-
Einen Tabellennamen, der eindeutig für Ihr Konto und Ihre Region ist.
-
Einen Primärschlüssel, für den jeder Wert eindeutig sein muss. Ihre Tabelle kann keine zwei Elemente mit demselben Primärschlüsselwert enthalten.
Ein Primärschlüssel kann einfach sein, also aus einem Schlüssel mit einer einzigen Partition (HASH) bestehen, oder zusammengesetzt, also aus einer Partition und einem Sortierschlüssel (RANGE).
Jeder Schlüsselwert hat einen zugehörigen Datentyp, der von der ScalarAttributeTypeKlasse aufgezählt wird. Der Schlüsselwert kann binär (B), numerisch (n) oder eine Zeichenfolge (S) sein. Weitere Informationen finden Sie unter Benennungsregeln und Datentypen imAmazon DynamoDB Entwicklerhandbuch.
-
Werte zum bereitgestellten Durchsatz, die die Anzahl der reservierten Lese-Schreib-Kapazitätseinheiten für die Tabelle angeben.
Anmerkung
Amazon DynamoDBDie Preisgestaltung
basiert auf den bereitgestellten Durchsatzwerten, die Sie in Ihren Tabellen festgelegt haben. Reservieren Sie also nur so viel Kapazität, wie Sie für Ihre Tabelle benötigen.
Der bereitgestellte Durchsatz für eine Tabelle kann jederzeit geändert werden. So können Sie die Kapazität anpassen, wenn sich Ihre Anforderungen ändern.
Erstellen einer Tabelle
Verwenden Sie diecreateTable
Methode des DynamoDBClients, um eine neueDynamoDB Tabelle zu erstellen. Sie müssen Tabellenattribute und ein Tabellenschema erstellen. Beide Komponenten fließen in den Primärschlüssel der Tabelle ein. Sie müssen auch anfänglich bereitgestellte Durchsatzwerte und einen Tabellennamen angeben. Definieren Sie nur wichtige Tabellenattribute beim Erstellen Ihrer DynamoDB-Tabelle.
Anmerkung
Wenn eine Tabelle mit dem von Ihnen ausgewählten Namen bereits existiert, AmazonServiceExceptionwird eine geworfen.
Importe
import com.amazonaws.AmazonServiceException; import com.amazonaws.services.dynamodbv2.AmazonDynamoDB; import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClientBuilder; import com.amazonaws.services.dynamodbv2.model.AttributeDefinition; import com.amazonaws.services.dynamodbv2.model.CreateTableRequest; import com.amazonaws.services.dynamodbv2.model.CreateTableResult; import com.amazonaws.services.dynamodbv2.model.KeySchemaElement; import com.amazonaws.services.dynamodbv2.model.KeyType; import com.amazonaws.services.dynamodbv2.model.ProvisionedThroughput; import com.amazonaws.services.dynamodbv2.model.ScalarAttributeType;
Erstellen einer Tabelle mit einem einfachen Primärschlüssel
Dieser Code erstellt eine Tabelle mit einem einfachen Primärschlüssel ("Name").
Code
CreateTableRequest request = new CreateTableRequest() .withAttributeDefinitions(new AttributeDefinition( "Name", ScalarAttributeType.S)) .withKeySchema(new KeySchemaElement("Name", KeyType.HASH)) .withProvisionedThroughput(new ProvisionedThroughput( new Long(10), new Long(10))) .withTableName(table_name); final AmazonDynamoDB ddb = AmazonDynamoDBClientBuilder.defaultClient(); try { CreateTableResult result = ddb.createTable(request); System.out.println(result.getTableDescription().getTableName()); } catch (AmazonServiceException e) { System.err.println(e.getErrorMessage()); System.exit(1); }
Das vollständige Beispiel
Erstellen einer Tabelle mit einem zusammengesetzten Primärschlüssel
Füge ein weiteres AttributeDefinitionund KeySchemaElementzu hinzu CreateTableRequest.
Code
CreateTableRequest request = new CreateTableRequest() .withAttributeDefinitions( new AttributeDefinition("Language", ScalarAttributeType.S), new AttributeDefinition("Greeting", ScalarAttributeType.S)) .withKeySchema( new KeySchemaElement("Language", KeyType.HASH), new KeySchemaElement("Greeting", KeyType.RANGE)) .withProvisionedThroughput( new ProvisionedThroughput(new Long(10), new Long(10))) .withTableName(table_name);
Das vollständige Beispiel
Auflisten von Tabellen
Sie können die Tabellen in einer bestimmten Region auflisten, indem Sie dielistTables
Methode des DynamoDBClients aufrufen.
Anmerkung
Wenn die benannte Tabelle für Ihr Konto und Ihre Region nicht existiert, ResourceNotFoundExceptionwird a ausgelöst.
Importe
import com.amazonaws.AmazonServiceException; import com.amazonaws.services.dynamodbv2.AmazonDynamoDB; import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClientBuilder; import com.amazonaws.services.dynamodbv2.model.ListTablesRequest; import com.amazonaws.services.dynamodbv2.model.ListTablesResult;
Code
final AmazonDynamoDB ddb = AmazonDynamoDBClientBuilder.defaultClient(); ListTablesRequest request; boolean more_tables = true; String last_name = null; while(more_tables) { try { if (last_name == null) { request = new ListTablesRequest().withLimit(10); } else { request = new ListTablesRequest() .withLimit(10) .withExclusiveStartTableName(last_name); } ListTablesResult table_list = ddb.listTables(request); List<String> table_names = table_list.getTableNames(); if (table_names.size() > 0) { for (String cur_name : table_names) { System.out.format("* %s\n", cur_name); } } else { System.out.println("No tables found!"); System.exit(0); } last_name = table_list.getLastEvaluatedTableName(); if (last_name == null) { more_tables = false; }
Standardmäßig werden bis zu 100 Tabellen pro Aufruf zurückgegeben. Verwenden Sie diese OptiongetLastEvaluatedTableName
für das zurückgegebene ListTablesResultObjekt, um die zuletzt ausgewertete Tabelle abzurufen. Mit diesem Wert können Sie die Auflistung nach dem zuletzt zurückgegebenen Wert der vorherigen Auflistung beginnen.
Das vollständige Beispiel
Beschreiben (Abrufen von Informationen zu) einer Tabelle
Rufen Sie diedescribeTable
Methode des DynamoDBClients auf.
Anmerkung
Wenn die benannte Tabelle für Ihr Konto und Ihre Region nicht existiert, ResourceNotFoundExceptionwird a ausgelöst.
Importe
import com.amazonaws.AmazonServiceException; import com.amazonaws.services.dynamodbv2.AmazonDynamoDB; import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClientBuilder; import com.amazonaws.services.dynamodbv2.model.AttributeDefinition; import com.amazonaws.services.dynamodbv2.model.ProvisionedThroughputDescription; import com.amazonaws.services.dynamodbv2.model.TableDescription;
Code
final AmazonDynamoDB ddb = AmazonDynamoDBClientBuilder.defaultClient(); try { TableDescription table_info = ddb.describeTable(table_name).getTable(); if (table_info != null) { System.out.format("Table name : %s\n", table_info.getTableName()); System.out.format("Table ARN : %s\n", table_info.getTableArn()); System.out.format("Status : %s\n", table_info.getTableStatus()); System.out.format("Item count : %d\n", table_info.getItemCount().longValue()); System.out.format("Size (bytes): %d\n", table_info.getTableSizeBytes().longValue()); ProvisionedThroughputDescription throughput_info = table_info.getProvisionedThroughput(); System.out.println("Throughput"); System.out.format(" Read Capacity : %d\n", throughput_info.getReadCapacityUnits().longValue()); System.out.format(" Write Capacity: %d\n", throughput_info.getWriteCapacityUnits().longValue()); List<AttributeDefinition> attributes = table_info.getAttributeDefinitions(); System.out.println("Attributes"); for (AttributeDefinition a : attributes) { System.out.format(" %s (%s)\n", a.getAttributeName(), a.getAttributeType()); } } } catch (AmazonServiceException e) { System.err.println(e.getErrorMessage()); System.exit(1); }
Das vollständige Beispiel
Ändern (Aktualisieren) einer Tabelle
Sie können die bereitgestellten Durchsatzwerte Ihrer Tabelle jederzeit ändern, indem Sie dieupdateTable
Methode des DynamoDBClients aufrufen.
Anmerkung
Wenn die benannte Tabelle für Ihr Konto und Ihre Region nicht existiert, ResourceNotFoundExceptionwird a ausgelöst.
Importe
import com.amazonaws.services.dynamodbv2.AmazonDynamoDB; import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClientBuilder; import com.amazonaws.services.dynamodbv2.model.ProvisionedThroughput; import com.amazonaws.AmazonServiceException;
Code
ProvisionedThroughput table_throughput = new ProvisionedThroughput( read_capacity, write_capacity); final AmazonDynamoDB ddb = AmazonDynamoDBClientBuilder.defaultClient(); try { ddb.updateTable(table_name, table_throughput); } catch (AmazonServiceException e) { System.err.println(e.getErrorMessage()); System.exit(1); }
Das vollständige Beispiel
Löschen einer Tabelle
Rufen Sie diedeleteTable
Methode des DynamoDBClients auf und übergeben Sie ihr den Namen der Tabelle.
Anmerkung
Wenn die benannte Tabelle für Ihr Konto und Ihre Region nicht existiert, ResourceNotFoundExceptionwird a ausgelöst.
Importe
import com.amazonaws.AmazonServiceException; import com.amazonaws.services.dynamodbv2.AmazonDynamoDB; import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClientBuilder;
Code
final AmazonDynamoDB ddb = AmazonDynamoDBClientBuilder.defaultClient(); try { ddb.deleteTable(table_name); } catch (AmazonServiceException e) { System.err.println(e.getErrorMessage()); System.exit(1); }
Das vollständige Beispiel
Weitere Infos
-
Richtlinien für die Arbeit mit Tabellen imAmazon DynamoDB Entwicklerhandbuch
-
Arbeiten mit TabellenDynamoDB imAmazon DynamoDB Entwicklerhandbuch