本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。
透過 AWS SDK 使用 PartiQL INSERT 陳述式插入 DynamoDB 資料
下列程式碼範例示範如何使用 PartiQL INSERT 陳述式插入資料。
- JavaScript
- 
            - 適用於 JavaScript (v3) 的 SDK
- 
             
                    搭配 PartiQL INSERT 陳述式將項目插入 DynamoDB 資料表 適用於 JavaScript 的 AWS SDK。 /** * This example demonstrates how to insert items into a DynamoDB table using PartiQL. * It shows different ways to insert documents with various index types. */ import { DynamoDBClient } from "@aws-sdk/client-dynamodb"; import { DynamoDBDocumentClient, ExecuteStatementCommand, BatchExecuteStatementCommand, } from "@aws-sdk/lib-dynamodb"; /** * Insert a single item into a DynamoDB table using PartiQL. * * @param tableName - The name of the DynamoDB table * @param item - The item to insert * @returns The response from the ExecuteStatementCommand */ export const insertItem = async (tableName: string, item: Record<string, any>) => { const client = new DynamoDBClient({}); const docClient = DynamoDBDocumentClient.from(client); // Convert the item to a string representation for PartiQL const itemString = JSON.stringify(item).replace(/"([^"]+)":/g, '$1:'); const params = { Statement: `INSERT INTO "${tableName}" VALUE ${itemString}`, }; try { const data = await docClient.send(new ExecuteStatementCommand(params)); console.log("Item inserted successfully"); return data; } catch (err) { console.error("Error inserting item:", err); throw err; } }; /** * Insert multiple items into a DynamoDB table using PartiQL batch operation. * This is more efficient than inserting items one by one. * * @param tableName - The name of the DynamoDB table * @param items - Array of items to insert * @returns The response from the BatchExecuteStatementCommand */ export const batchInsertItems = async (tableName: string, items: Record<string, any>[]) => { const client = new DynamoDBClient({}); const docClient = DynamoDBDocumentClient.from(client); // Create statements for each item const statements = items.map((item) => { const itemString = JSON.stringify(item).replace(/"([^"]+)":/g, '$1:'); return { Statement: `INSERT INTO "${tableName}" VALUE ${itemString}`, }; }); const params = { Statements: statements, }; try { const data = await docClient.send(new BatchExecuteStatementCommand(params)); console.log("Items inserted successfully"); return data; } catch (err) { console.error("Error batch inserting items:", err); throw err; } }; /** * Insert an item with a condition to prevent overwriting existing items. * This is useful for ensuring you don't accidentally overwrite data. * * @param tableName - The name of the DynamoDB table * @param item - The item to insert * @param partitionKeyName - The name of the partition key attribute * @returns The response from the ExecuteStatementCommand */ export const insertItemWithCondition = async ( tableName: string, item: Record<string, any>, partitionKeyName: string ) => { const client = new DynamoDBClient({}); const docClient = DynamoDBDocumentClient.from(client); const itemString = JSON.stringify(item).replace(/"([^"]+)":/g, '$1:'); const partitionKeyValue = JSON.stringify(item[partitionKeyName]); const params = { Statement: `INSERT INTO "${tableName}" VALUE ${itemString} WHERE attribute_not_exists(${partitionKeyName})`, Parameters: [{ S: partitionKeyValue }], }; try { const data = await docClient.send(new ExecuteStatementCommand(params)); console.log("Item inserted with condition successfully"); return data; } catch (err) { console.error("Error inserting item with condition:", err); throw err; } }; /** * Example usage showing how to insert items with different index types */ export const insertExamples = async () => { // Example table with a simple primary key (just partition key) const simpleKeyItem = { userId: "user123", name: "John Doe", email: "john@example.com", }; await insertItem("UsersTable", simpleKeyItem); // Example table with composite key (partition key + sort key) const compositeKeyItem = { orderId: "order456", productId: "prod789", quantity: 2, price: 29.99, }; await insertItem("OrdersTable", compositeKeyItem); // Example with Global Secondary Index (GSI) // The GSI might be on the email attribute const gsiItem = { userId: "user789", email: "jane@example.com", name: "Jane Smith", userType: "premium", // This could be part of a GSI }; await insertItem("UsersTable", gsiItem); // Example with Local Secondary Index (LSI) // LSI uses the same partition key but different sort key const lsiItem = { orderId: "order567", // Partition key productId: "prod123", // Sort key for the table orderDate: "2023-11-15", // Potential sort key for an LSI quantity: 1, price: 19.99, }; await insertItem("OrdersTable", lsiItem); // Batch insert example with multiple items const batchItems = [ { userId: "user234", name: "Alice Johnson", email: "alice@example.com", }, { userId: "user345", name: "Bob Williams", email: "bob@example.com", }, ]; await batchInsertItems("UsersTable", batchItems); };- 
                    如需 API 詳細資訊,請參閱《適用於 JavaScript 的 AWS SDK API 參考》中的下列主題。 
 
- 
                    
 
如需 AWS SDK 開發人員指南和程式碼範例的完整清單,請參閱 搭配 AWS SDK 使用 DynamoDB 。此主題也包含有關入門的資訊和舊版 SDK 的詳細資訊。
偵測映像中的 PPE
從瀏覽器調用 Lambda 函數