Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Sinkronkan
Dokumen pemetaan Sync
permintaan memungkinkan Anda mengambil semua hasil dari tabel DynamoDB dan kemudian hanya menerima data yang diubah sejak kueri terakhir Anda (pembaruan delta). Sync
permintaan hanya dapat dibuat ke sumber data DynamoDB berversi. Anda dapat menentukan sebagai berikut:
-
Filter untuk mengecualikan hasil
-
Berapa banyak item yang akan dikembalikan
-
Token Paginasi
-
Ketika
Sync
operasi terakhir Anda dimulai
Dokumen Sync
pemetaan memiliki struktur sebagai berikut:
{ "version" : "2018-05-29", "operation" : "Sync", "basePartitionKey": "Base Tables PartitionKey", "deltaIndexName": "delta-index-name", "limit" : 10, "nextToken" : "aPaginationToken", "lastSync" : 1550000000000, "filter" : { ... } }
Bidang didefinisikan sebagai berikut:
Bidang sinkronisasi
-
version
-
Versi definisi template. Hanya saat
2018-05-29
ini didukung. Nilai ini diperlukan. -
operation
-
Operasi DynamoDB untuk melakukan. Untuk melakukan
Sync
operasi, ini harus diatur keSync
. Nilai ini diperlukan. -
filter
-
Filter yang dapat digunakan untuk memfilter hasil dari DynamoDB sebelum dikembalikan. Untuk informasi selengkapnya tentang filter, lihat Menyaring. Bidang ini bersifat opsional.
-
limit
-
Jumlah maksimum item untuk dievaluasi pada satu waktu. Bidang ini bersifat opsional. Jika dihilangkan, batas default akan diatur ke
100
item. Nilai maksimum untuk bidang ini adalah1000
item. -
nextToken
-
Token pagination untuk melanjutkan kueri sebelumnya. Ini akan diperoleh dari kueri sebelumnya. Bidang ini bersifat opsional.
-
lastSync
-
Momen, dalam milidetik zaman, ketika
Sync
operasi sukses terakhir dimulai. Jika ditentukan, hanya item yang telah berubah setelahlastSync
dikembalikan. Bidang ini opsional, dan hanya boleh diisi setelah mengambil semua halaman dari operasi awalSync
. Jika dihilangkan, hasil dari tabel Base akan dikembalikan, jika tidak, hasil dari tabel Delta akan dikembalikan. basePartitionKey
-
Kunci partisi dari tabel Basis yang digunakan saat melakukan
Sync
operasi. Bidang ini memungkinkanSync
operasi yang akan dilakukan ketika tabel menggunakan kunci partisi kustom. Ini adalah bidang opsional. deltaIndexName
-
Indeks yang digunakan untuk
Sync
operasi. Indeks ini diperlukan untuk mengaktifkanSync
operasi di seluruh tabel penyimpanan delta saat tabel menggunakan kunci partisi khusus.Sync
Operasi akan dilakukan pada GSI (dibuat padagsi_ds_pk
dangsi_ds_sk
). Bidang ini bersifat opsional.
Hasil yang dikembalikan oleh sinkronisasi DynamoDB secara otomatis diubah menjadi tipe primitif GraphQL dan JSON dan tersedia dalam konteks pemetaan (). $context.result
Untuk informasi selengkapnya tentang konversi tipe DynamoDB, lihat Mengetik sistem (pemetaan respons).
Untuk informasi selengkapnya tentang template pemetaan respons, lihat Ringkasan template pemetaan Resolver.
Hasilnya memiliki struktur sebagai berikut:
{ items = [ ... ], nextToken = "a pagination token", scannedCount = 10, startedAt = 1550000000000 }
Bidang didefinisikan sebagai berikut:
-
items
-
Daftar yang berisi item yang dikembalikan oleh sinkronisasi.
-
nextToken
-
Jika mungkin ada lebih banyak hasil,
nextToken
berisi token pagination yang dapat Anda gunakan dalam permintaan lain. AWS AppSync mengenkripsi dan mengaburkan token pagination yang dikembalikan dari DynamoDB. Ini mencegah data tabel Anda bocor secara tidak sengaja ke penelepon. Selain itu, token pagination ini tidak dapat digunakan di berbagai resolver. -
scannedCount
-
Jumlah item yang diambil oleh DynamoDB sebelum ekspresi filter (jika ada) diterapkan.
-
startedAt
-
Saat ini, dalam milidetik epoch, ketika operasi sinkronisasi dimulai yang dapat Anda simpan secara lokal dan gunakan dalam permintaan lain sebagai argumen Anda.
lastSync
Jika token pagination disertakan dalam permintaan, nilai ini akan sama dengan yang dikembalikan oleh permintaan untuk halaman pertama hasil.
Contoh
Contoh berikut adalah template pemetaan untuk query GraphQL:. syncPosts(nextToken: String, lastSync: AWSTimestamp)
Dalam contoh ini, jika lastSync
dihilangkan, semua entri dalam tabel dasar dikembalikan. Jika lastSync
disediakan, hanya entri dalam tabel sinkronisasi delta yang telah berubah sejak itu lastSync
dikembalikan.
{ "version" : "2018-05-29", "operation" : "Sync", "limit": 100, "nextToken": $util.toJson($util.defaultIfNull($ctx.args.nextToken, null)), "lastSync": $util.toJson($util.defaultIfNull($ctx.args.lastSync, null)) }