Programming Tutorial

Membuat View dan Materialized View di PostgreSQL

TUKANG KETIK
Agustus 28, 2024
0 Komentar
Beranda
Programming
Tutorial
Membuat View dan Materialized View di PostgreSQL

img source: medium.com

PostgreSQL adalah salah satu database relasional yang paling kaya fitur dan andal. Dua fitur penting yang sering digunakan dalam manajemen data adalah View dan Materialized View. Masing-masing memiliki kegunaan spesifik yang membantu dalam pengelolaan query yang kompleks serta pengoptimalan kinerja. Artikel ini akan menjelaskan cara membuat View dan Materialized View di PostgreSQL, serta manfaat dari masing-masing.

Apa Itu View di PostgreSQL?

View adalah tabel virtual yang menyajikan hasil dari sebuah query SQL. View tidak menyimpan data secara fisik; sebaliknya, setiap kali View dipanggil, query yang mendasarinya akan dieksekusi. View sangat berguna untuk menyederhanakan query yang kompleks, meningkatkan keamanan data, dan memudahkan pengelolaan database.

Langkah-langkah Membuat View:

  1. Tentukan Data yang Akan Ditampilkan: Pilih kolom dan kondisi data yang ingin Anda masukkan dalam View.

  2. Tulis Perintah SQL: Gunakan perintah CREATE VIEW diikuti dengan nama View yang diinginkan, serta query SQL yang akan menghasilkan data.

    Contoh:

    CREATE VIEW active_employees AS
    SELECT employee_id, employee_name, department
    FROM employees
    WHERE status = 'active';
  3. Mengakses Data Melalui View: Anda dapat mengakses View seperti tabel biasa.

    Contoh:

    SELECT * FROM active_employees;

Manfaat View:

  • Menyederhanakan Query: View membantu mengabstraksi query yang kompleks, memudahkan pengguna untuk mengakses data.
  • Keamanan Data: Dengan menggunakan View, Anda bisa membatasi akses pengguna ke kolom tertentu, menjaga keamanan data sensitif.
  • Pemeliharaan yang Mudah: Ketika ada perubahan pada logika query, Anda cukup memperbarui View tanpa mengubah semua query yang mengakses data tersebut.

Apa Itu Materialized View di PostgreSQL?

Materialized View adalah tabel fisik yang menyimpan hasil dari query SQL pada saat Materialized View dibuat. Berbeda dengan View biasa, Materialized View menyimpan data secara fisik sehingga memungkinkan query diakses lebih cepat, terutama untuk dataset yang besar dan query yang rumit. Namun, karena data disimpan, Materialized View memerlukan pembaruan secara berkala agar data tetap sinkron dengan sumbernya.

Langkah-langkah Membuat Materialized View:

  1. Tentukan Query untuk Materialized View: Sama seperti pada View biasa, tentukan query yang akan menghasilkan data untuk Materialized View.

  2. Tulis Perintah SQL: Gunakan perintah CREATE MATERIALIZED VIEW diikuti dengan nama Materialized View yang diinginkan.

    Contoh:

    CREATE MATERIALIZED VIEW sales_summary AS
    SELECT department_id, SUM(amount) as total_sales
    FROM sales
    GROUP BY department_id;
  3. Mengakses Data dari Materialized View: Anda bisa mengakses Materialized View seperti tabel biasa.

    Contoh:

    SELECT * FROM sales_summary;
  4. Menyegarkan Materialized View: Karena data pada Materialized View tidak otomatis diperbarui, Anda perlu menyegarkannya secara manual menggunakan perintah REFRESH MATERIALIZED VIEW.

    Contoh:

    REFRESH MATERIALIZED VIEW sales_summary;

Manfaat Materialized View:

  • Peningkatan Kinerja Query: Karena data disimpan secara fisik, Materialized View memungkinkan akses data yang lebih cepat untuk query yang rumit.
  • Stabilitas Data: Data dalam Materialized View tidak berubah kecuali diperbarui, memberikan stabilitas untuk analisis data yang memerlukan konsistensi.
  • Optimasi Ruang Penyimpanan: Dengan menyimpan hasil query yang berat, Materialized View mengurangi beban komputasi dan waktu eksekusi query berulang.

Kesimpulan

Baik View maupun Materialized View adalah fitur yang sangat berguna di PostgreSQL untuk mengelola dan mengoptimalkan akses data. View cocok untuk menyederhanakan query kompleks dan meningkatkan keamanan data, sementara Materialized View ideal untuk meningkatkan kinerja query dengan menyimpan hasil query yang berat. Dengan memilih dan menggunakan fitur yang tepat, Anda dapat meningkatkan efisiensi dan performa database PostgreSQL Anda.


Referensi:

Penulis blog

TUKANG KETIK
TUKANG KETIK
Programming is 10% writing code, and 90% understanding why it's not working. Coding is trial & error.

Tidak ada komentar

Tolong Ketikannya di jaga dan gunakan bahasa yang sopan. Terima kasih
Atau Boleh request juga artikel apa yang ingin saya bahas ditulisan saya (tapi ini kalau saya bisa dan waktunya ada) maklum saya juga kerja.