UpdateItem
UpdateItem
リクエストでは、AWS AppSync DynamoDB の関数 から DynamoDB への UpdateItem
リクエストを定義し、以下のように指定できます。
-
DynamoDB の項目のキー
-
DynamoDB の項目を更新する方法を示す更新式
-
処理が成功する条件
UpdateItem
リクエストの構造は次のとおりです。
type DynamoDBUpdateItemRequest = { operation: 'UpdateItem'; key: { [key: string]: any }; update: { expression: string; expressionNames?: { [key: string]: string }; expressionValues?: { [key: string]: any }; }; condition?: ConditionCheckExpression; customPartitionKey?: string; populateIndexFields?: boolean; _version?: number; };
各フィールドの定義は以下のようになります。
UpdateItem フィールド
-
operation
-
実行する DynamoDB の処理。
UpdateItem
DynamoDB の処理を実行するには、これをUpdateItem
に設定する必要があります。この値は必須です。 -
key
-
DynamoDB の項目のキー。DynamoDB の項目には、単一のハッシュキー、またはハッシュキーとソートキーが含まれています。これはテーブルの構造によって変わります。「型付き値」を指定する方法の詳細については、「型システム (リクエストマッピング)」を参照してください。この値は必須です。
-
update
-
update
セクションには、 DynamoDBの項目の更新方法を示す更新式を指定することができます。更新式の記述方法の詳細については、「DynamoDB UpdateExpressions」のドキュメントを参照してください。このセクションは必須です。update
セクションには次の 3 つのコンポーネントがあります。-
expression
-
更新式です。この値は必須です。
-
expressionNames
-
式の属性名のプレースホルダーを示します。キー - 値のペアの形式になります。キーは
expression
で使用される名前のプレースホルダーに対応し、値は DynamoDB の項目の属性名と一致する文字列でなければなりません。このフィールドはオプションであり、expression
で使用される式の属性名のプレースホルダーのみを入力します。 -
expressionValues
-
式の属性値のプレースホルダーを示します。キー - 値のペアの形式になります。キーは
expression
で使用される値のプレースホルダーに対応し、値は型付き値でなければなりません。「型付き値」を指定する方法の詳細については、「型システム (リクエストマッピング)」を参照してください。この指定は必須です。このフィールドはオプションであり、expression
で使用される式の属性値のプレースホルダーのみを入力します。
-
-
condition
-
DynamoDB 内に既に存在するオブジェクトの状態に基づき、リクエストが成功するかどうかを判断する条件です。条件を指定していない場合は、
UpdateItem
リクエストによって、現在の状態にかかわらず、既存のエントリが更新されます。条件の詳細については、「条件式」を参照してください。この値はオプションです。 -
_version
-
項目の既知の最新バージョンを表す数値。この値はオプションです。このフィールドは競合の検出に使用され、バージョン管理されたデータソースでのみサポートされます。
customPartitionKey
-
有効にすると、この文字列値は、バージョニングが有効になっているときにデルタ同期テーブルで使用される
ds_sk
およびds_pk
レコードの形式を変更します (詳細については、「AWS AppSyncデベロッパーガイド」の「競合検出と同期」を参照)。有効にすると、populateIndexFields
エントリの処理も有効になります。このフィールドはオプションです。 populateIndexFields
-
ブール値で、
customPartitionKey
と一緒に有効にすると、差分同期テーブル、具体的にはgsi_ds_pk
とgsi_ds_sk
列のレコードごとに新しいエントリが作成されます。詳細については、「AWS AppSyncデベロッパーガイド」の「競合検出と同期」を参照してください。このフィールドはオプションです。
DynamoDB の更新された項目が自動的に GraphQL プリミティブ型と JSON プリミティブ型に変換され、コンテキスト結果 (context.result
) で参照できます。
DynamoDB の型変換の詳細については、「型システム (リクエストマッピング)」を参照してください。
JavaScript リゾルバーの詳細については、「JavaScript リゾルバーの概要」を参照してください。
例 1
次の例は、GraphQL ミューテーション upvote(id: ID!)
の関数リクエストハンドラーです。
この例では、DynamoDB の項目の upvotes
フィールドと version
フィールドが 1 ずつ増加されます。
import { util } from '@aws-appsync/utils'; export function request(ctx) { const { id } = ctx.args; return { operation: 'UpdateItem', key: util.dynamodb.toMapValues({ id }), update: { expression: 'ADD #votefield :plusOne, version :plusOne', expressionNames: { '#votefield': 'upvotes' }, expressionValues: { ':plusOne': { N: 1 } }, }, }; }
例 2
次の例は、GraphQL ミューテーション updateItem(id: ID!, title: String, author: String, expectedVersion:
Int!)
の関数リクエストハンドラーです。
これは、引数を確認して、クライアントから入力された引数のみを含む更新式を動的に生成する複雑な例です。たとえば、title
と author
を省略すると、それらは更新されません。引数が指定されているが、その値が null
の場合、そのフィールドは DynamoDB のオブジェクトから削除されます。最後に、この処理内の条件によって、DynamoDB に現在ある項目の version
フィールドに expectedVersion
が設定されているかどうかを確認します。
import { util } from '@aws-appsync/utils'; export function request(ctx) { const { args: { input: { id, ...values } } } = ctx; const condition = { id: { attributeExists: true }, version: { eq: values.expectedVersion }, }; values.expectedVersion += 1; return dynamodbUpdateRequest({ keys: { id }, values, condition }); } /** * Helper function to update an item * @returns an UpdateItem request */ function dynamodbUpdateRequest(params) { const { keys, values, condition: inCondObj } = params; const sets = []; const removes = []; const expressionNames = {}; const expValues = {}; // Iterate through the keys of the values for (const [key, value] of Object.entries(values)) { expressionNames[`#${key}`] = key; if (value) { sets.push(`#${key} = :${key}`); expValues[`:${key}`] = value; } else { removes.push(`#${key}`); } } let expression = sets.length ? `SET ${sets.join(', ')}` : ''; expression += removes.length ? ` REMOVE ${removes.join(', ')}` : ''; const condition = JSON.parse( util.transform.toDynamoDBConditionExpression(inCondObj) ); return { operation: 'UpdateItem', key: util.dynamodb.toMapValues(keys), condition, update: { expression, expressionNames, expressionValues: util.dynamodb.toMapValues(expValues), }, }; }
DynamoDB UpdateItem
API の詳細については、「DynamoDB API のドキュメント」を参照してください。