Halaman ini menjelaskan permintaan operasi tulis batch Spanner dan cara menggunakannya untuk mengubah data Spanner.
Anda dapat menggunakan penulisan batch Spanner untuk menyisipkan, memperbarui, atau menghapus beberapa baris di tabel Spanner. Tulis batch Spanner mendukung operasi tulis latensi rendah tanpa operasi baca, dan menampilkan respons saat mutasi diterapkan dalam batch. Untuk menggunakan penulisan batch, Anda mengelompokkan mutasi terkait, dan semua mutasi dalam grup di-commit secara atomik. Mutasi di seluruh grup diterapkan dalam urutan yang tidak ditentukan dan tidak saling bergantung (non-atomik). Spanner tidak perlu menunggu semua mutasi diterapkan sebelum mengirim respons, yang berarti bahwa operasi tulis batch memungkinkan kegagalan sebagian. Anda juga dapat menjalankan beberapa operasi tulis batch sekaligus. Untuk mengetahui informasi selengkapnya, lihat Cara menggunakan penulisan batch.
Kasus penggunaan
Penulisan batch Spanner sangat berguna jika Anda ingin melakukan penulisan dalam jumlah besar tanpa operasi baca, tetapi tidak memerlukan transaksi atomik untuk semua mutasi Anda.
Jika Anda ingin mengelompokkan permintaan DML, gunakan DML batch untuk mengubah data Spanner. Untuk mengetahui informasi selengkapnya tentang perbedaan antara DML dan mutasi, lihat Membandingkan DML dan mutasi.
Untuk permintaan mutasi tunggal, sebaiknya gunakan transaksi baca-tulis penguncian.
Batasan
Operasi tulis batch Spanner memiliki batasan berikut:
Penulisan batch Spanner tidak tersedia menggunakan konsol Google Cloud atau Google Cloud CLI. API ini hanya tersedia menggunakan API REST dan RPC serta library klien Java Spanner.
Perlindungan replay tidak didukung menggunakan penulisan batch. Mutasi dapat diterapkan lebih dari sekali, dan mutasi yang diterapkan lebih dari sekali dapat menyebabkan kegagalan. Misalnya, jika mutasi penyisipan diputar ulang, mutasi tersebut mungkin menghasilkan error sudah ada, atau jika Anda menggunakan kunci berbasis stempel waktu yang dihasilkan atau commit dalam mutasi, mutasi tersebut dapat menyebabkan baris tambahan ditambahkan ke tabel. Sebaiknya strukturkan operasi tulis Anda agar bersifat idempoten untuk menghindari masalah ini.
Anda tidak dapat melakukan rollback permintaan operasi tulis batch yang telah selesai. Anda dapat membatalkan permintaan operasi tulis batch yang sedang berlangsung. Jika Anda membatalkan operasi tulis batch yang sedang berlangsung, mutasi dalam grup yang belum selesai akan di-roll back. Mutasi dalam grup yang telah selesai di-commit ke database.
Ukuran maksimum untuk permintaan tulis batch sama dengan batas untuk permintaan commit. Untuk mengetahui informasi selengkapnya, lihat Batas untuk membuat, membaca, memperbarui, dan menghapus data.
Cara menggunakan penulisan batch
Untuk menggunakan operasi tulis batch, Anda harus memiliki izin spanner.databases.write
di database yang ingin diubah. Anda dapat menulis mutasi secara massal
secara non-atomik dalam satu panggilan menggunakan panggilan permintaan REST
atau RPC API.
Anda harus mengelompokkan jenis mutasi berikut secara bersamaan saat menggunakan operasi tulis batch:
- Menyisipkan baris dengan awalan kunci utama yang sama di tabel induk dan turunan.
- Menyisipkan baris ke dalam tabel dengan hubungan kunci asing di antara tabel.
- Jenis mutasi terkait lainnya bergantung pada skema database dan logika aplikasi Anda.
Anda juga dapat melakukan penulisan secara batch menggunakan library klien Java Spanner.
Contoh kode berikut memperbarui tabel Singers
dengan baris baru.
Java
Langkah selanjutnya
- Pelajari transaksi Spanner lebih lanjut.