Saat baris tabel ditambahkan, dihapus, atau diperbarui, columnar engine tidak langsung memperbarui data di penyimpanan kolom. Sebagai gantinya, konten yang terpengaruh di penyimpanan kolom ditandai sebagai tidak valid, dan kueri direncanakan dan dieksekusi menggunakan data berorientasi kolom dari penyimpanan kolom dan data berorientasi baris dari cache baris dan penyimpanan database.
Seiring waktu, karena semakin banyak blok data yang menjadi tidak valid, peningkatan performa kueri yang diberikan oleh columnar engine akan berkurang hingga data berbasis kolom perlu di-refresh untuk mendapatkan kembali peningkatan performa kueri. Saat nilai minimum refresh ini tercapai, columnar engine akan menggunakan tugas latar belakang untuk me-refresh data yang tidak valid di penyimpanan kolom. Secara default, columnar engine menggunakan nilai minimum refresh 50, yang menunjukkan bahwa konten tertentu di penyimpanan kolom akan ditandai untuk di-refresh jika 50% kontennya menjadi tidak valid. Anda dapat mengubah nilai minimum refresh ini untuk menyesuaikan overhead refresh otomatis dan berpotensi mendapatkan performa kueri berkelanjutan yang lebih baik untuk beban kerja aplikasi Anda.
Selain itu, Anda dapat memuat ulang data tabel secara manual di column store kapan saja. Biasanya, Anda melakukan refresh manual saat ingin perubahan pada tabel ditampilkan di column store sesegera mungkin setelah melakukan perubahan.
Mengubah nilai minimum refresh columnar engine
Edit nilai flag database
google_columnar_engine.refresh_threshold_percentage untuk mengubah
nilai minimum refresh columnar engine.
ALTER SYSTEM SET google_columnar_engine.refresh_threshold_percentage=THRESHOLD;
THRESHOLD: nilai bilangan bulat antara 1 dan
100. Nilai ini menentukan persentase blok data dalam konten
yang harus menjadi tidak valid agar konten ditandai untuk diperbarui.
Memuat ulang data tabel secara manual di column store
Jalankan fungsi SQL google_columnar_engine_refresh untuk memuat ulang data tabel secara manual di penyimpanan kolom dalam memori.
SELECT google_columnar_engine_refresh(TABLE_NAME);
TABLE_NAME: string yang berisi nama tabel atau tampilan terwujud. Jika tabel atau tampilan berada dalam skema selain public, tentukan nama skema menggunakan format SCHEMA_NAME.TABLE_NAME—misalnya, myschema.mytable.