MySQLi - INDEKS
Indeks database adalah struktur data yang meningkatkan kecepatan operasi dalam tabel. Indeks dapat dibuat menggunakan satu atau beberapa kolom, memberikan dasar untuk pencarian acak cepat dan pengurutan akses ke rekaman yang efisien.
Saat membuat indeks, harus diperhatikan bahwa kolom apa saja yang akan digunakan untuk membuat kueri SQL dan membuat satu atau lebih indeks pada kolom tersebut.
Secara praktis, indeks juga merupakan tipe tabel, yang menyimpan kunci utama atau bidang indeks dan penunjuk ke setiap rekaman ke dalam tabel aktual.
Pengguna tidak dapat melihat indeks, mereka hanya digunakan untuk mempercepat kueri dan akan digunakan oleh Mesin Pencari Database untuk menemukan catatan dengan sangat cepat.
Pernyataan INSERT dan UPDATE membutuhkan lebih banyak waktu pada tabel yang memiliki indeks dimana pernyataan SELECT menjadi cepat pada tabel tersebut. Alasannya adalah saat melakukan insert atau update, database perlu memasukkan atau mengupdate nilai indeks juga.
Indeks Sederhana dan Unik
Anda dapat membuat indeks unik di atas tabel. Indeks unik berarti bahwa dua baris tidak boleh memiliki nilai indeks yang sama. Berikut ini sintaks untuk membuat Indeks di atas tabel.
CREATE UNIQUE INDEX index_name ON table_name ( column1, column2,...);
Anda dapat menggunakan satu atau beberapa kolom untuk membuat indeks. Misalnya, kita dapat membuat indeks di tutorials_inf menggunakan NAME_INDEX.
CREATE UNIQUE INDEX NAME_INDEX ON tutorials_inf(name);
Anda dapat membuat indeks sederhana di atas tabel. Hapus saja kata kunci UNIK dari kueri untuk membuat indeks sederhana. Indeks sederhana memungkinkan nilai duplikat dalam tabel.
Jika Anda ingin mengindeks nilai dalam kolom dalam urutan menurun, Anda dapat menambahkan kata khusus DESC setelah nama kolom.
mysql> CREATE UNIQUE INDEX NAME_INDEX ON tutorials_inf (name DESC);
ALTER perintah untuk menambah dan melepaskan INDEX
Ada empat jenis pernyataan untuk menambahkan indeks ke tabel -
ALTER TABLE tbl_name ADD PRIMARY KEY (column_list) - Pernyataan ini menambahkan PRIMARY KEY, yang berarti nilai yang diindeks harus unik dan tidak boleh NULL.
ALTER TABLE tbl_name ADD UNIQUE index_name (column_list) - Pernyataan ini membuat indeks yang nilainya harus unik (dengan pengecualian nilai NULL, yang mungkin muncul beberapa kali).
ALTER TABLE tbl_name ADD INDEX index_name (column_list) - Ini menambahkan indeks biasa di mana nilai apa pun dapat muncul lebih dari sekali.
ALTER TABLE tbl_name ADD FULLTEXT index_name (column_list) - Ini membuat indeks FULLTEXT khusus yang digunakan untuk tujuan pencarian teks.
Berikut adalah contoh untuk menambahkan indeks pada tabel yang sudah ada.
mysql> ALTER TABLE tutorials_inf ADD INDEX (id);
Anda dapat menjatuhkan INDEX apa pun dengan menggunakan klausa DROP bersama dengan perintah ALTER. Coba contoh berikut untuk menjatuhkan indeks yang dibuat di atas.
mysql> ALTER TABLE tutorials_inf DROP INDEX (c);
Anda dapat menjatuhkan INDEX apa pun dengan menggunakan klausa DROP bersama dengan perintah ALTER. Coba contoh berikut untuk menjatuhkan indeks yang dibuat di atas.
ALTER Perintah untuk menambah dan melepas PRIMARY KEY
Anda juga dapat menambahkan kunci utama dengan cara yang sama. Tetapi pastikan Kunci Utama berfungsi pada kolom, yang BUKAN NIHIL.
Berikut adalah contoh untuk menambahkan kunci utama pada tabel yang sudah ada. Ini akan membuat kolom NOT NULL terlebih dahulu dan kemudian menambahkannya sebagai kunci utama.
mysql> ALTER TABLE tutorials_inf MODIFY id INT NOT NULL;
mysql> ALTER TABLE tutorials_inf ADD PRIMARY KEY (id);
Anda dapat menggunakan perintah ALTER untuk melepaskan kunci utama sebagai berikut:
mysql> ALTER TABLE tutorials_inf DROP PRIMARY KEY;
Untuk menghapus indeks yang bukan PRIMARY KEY, Anda harus menentukan nama indeks.
Menampilkan Informasi INDEX
Anda dapat menggunakan perintah SHOW INDEX untuk mendaftar semua indeks yang terkait dengan tabel. Output format vertikal (ditentukan oleh \ G) sering kali berguna dengan pernyataan ini, untuk menghindari garis batas panjang -
Coba contoh berikut
mysql> SHOW INDEX FROM table_name\G
........