PostgreSQL - INDEKS

Indeks adalah tabel pencarian khusus yang dapat digunakan mesin pencari database untuk mempercepat pengambilan data. Sederhananya, indeks adalah penunjuk ke data dalam tabel. Indeks dalam database sangat mirip dengan indeks di bagian belakang buku.

Misalnya, jika Anda ingin mereferensikan semua halaman dalam sebuah buku yang membahas topik tertentu, Anda harus merujuk ke indeks terlebih dahulu, yang mencantumkan semua topik berdasarkan abjad dan kemudian merujuk ke satu atau beberapa nomor halaman tertentu.

Sebuah indeks membantu untuk mempercepat query SELECT dan klausa WHERE; namun, ini memperlambat input data, dengan pernyataan UPDATE dan INSERT. Indeks dapat dibuat atau dihapus tanpa berpengaruh pada data.

Membuat indeks melibatkan pernyataan CREATE INDEX, yang memungkinkan Anda memberi nama indeks, menentukan tabel dan kolom atau kolom mana yang akan diindeks, dan untuk menunjukkan apakah indeks dalam urutan naik atau turun.

Indeks juga bisa unik, mirip dengan batasan UNIK, di mana indeks mencegah entri duplikat dalam kolom atau kombinasi kolom yang memiliki indeks.

Perintah CREATE INDEX

Sintaks dasar CREATE INDEX adalah sebagai berikut -

CREATE INDEX index_name ON table_name;

Jenis Indeks

PostgreSQL menyediakan beberapa jenis indeks: B-tree, Hash, GiST, SP-GiST dan GIN. Setiap jenis Indeks menggunakan algoritme berbeda yang paling cocok untuk berbagai jenis kueri. Secara default, perintah BUAT INDEKS membuat indeks pohon-B, yang sesuai dengan situasi paling umum.

Indeks Kolom Tunggal

Indeks satu kolom adalah indeks yang dibuat hanya berdasarkan satu kolom tabel. Sintaks dasarnya adalah sebagai berikut -

CREATE INDEX index_name
ON table_name (column_name);

Indeks Multikolom

Indeks multikolom didefinisikan di lebih dari satu kolom tabel. Sintaks dasarnya adalah sebagai berikut -

CREATE INDEX index_name
ON table_name (column1_name, column2_name);

Apakah akan membuat indeks kolom tunggal atau indeks multikolom, pertimbangkan kolom yang mungkin Anda gunakan sangat sering dalam klausa WHERE kueri sebagai kondisi filter.

Jika hanya ada satu kolom yang digunakan, indeks satu kolom harus menjadi pilihan. Jika ada dua atau lebih kolom yang sering digunakan dalam klausa WHERE sebagai filter, indeks multikolom akan menjadi pilihan terbaik.

Indeks Unik

Indeks unik digunakan tidak hanya untuk kinerja, tetapi juga untuk integritas data. Indeks unik tidak mengizinkan nilai duplikat untuk dimasukkan ke dalam tabel. Sintaks dasarnya adalah sebagai berikut -

CREATE UNIQUE INDEX index_name
on table_name (column_name);

Indeks Parsial

Indeks parsial adalah indeks yang dibangun di atas subset tabel; subset didefinisikan oleh ekspresi kondisional (disebut predikat indeks parsial). Indeks berisi entri hanya untuk baris tabel yang memenuhi predikat. Sintaks dasarnya adalah sebagai berikut -

CREATE INDEX index_name
on table_name (conditional_expression);

Indeks Implisit

Indeks implisit adalah indeks yang secara otomatis dibuat oleh server database saat objek dibuat. Indeks secara otomatis dibuat untuk batasan kunci utama dan batasan unik.

Contoh

Berikut adalah contoh di mana kita akan membuat indeks pada tabel PERUSAHAAN untuk kolom gaji -

# CREATE INDEX salary_index ON COMPANY (salary);

Sekarang, mari kita daftar semua indeks yang tersedia di tabel PERUSAHAAN menggunakan \d company perintah.

# \d company

Ini akan menghasilkan hasil berikut, di mana company_pkey adalah indeks implisit, yang dibuat saat tabel dibuat.

Table "public.company"
 Column  |     Type      | Modifiers
---------+---------------+-----------
 id      | integer       | not null
 name    | text          | not null
 age     | integer       | not null
 address | character(50) |
 salary  | real          |
Indexes:
    "company_pkey" PRIMARY KEY, btree (id)
    "salary_index" btree (salary)

Anda dapat membuat daftar seluruh database indeks menggunakan ekstensi \di perintah -

Perintah DROP INDEX

Indeks dapat dijatuhkan menggunakan PostgreSQL DROPperintah. Kehati-hatian harus diambil saat menurunkan indeks karena kinerja mungkin melambat atau ditingkatkan.

Sintaks dasarnya adalah sebagai berikut -

DROP INDEX index_name;

Anda dapat menggunakan pernyataan berikut untuk menghapus indeks yang dibuat sebelumnya -

# DROP INDEX salary_index;

Kapan Indeks Harus Dihindari?

Meskipun indeks dimaksudkan untuk meningkatkan kinerja database, ada kalanya indeks harus dihindari. Panduan berikut menunjukkan kapan penggunaan indeks harus dipertimbangkan kembali -

  • Indeks tidak boleh digunakan pada tabel kecil.

  • Tabel yang memiliki operasi penyisipan atau pembaruan batch besar yang sering.

  • Indeks tidak boleh digunakan pada kolom yang berisi nilai NULL dalam jumlah tinggi.

  • Kolom yang sering dimanipulasi tidak boleh diindeks.