Mysql
 sql >> Teknologi Basis Data >  >> RDS >> Mysql

Kapan menambahkan indeks pada bidang tabel SQL (MySQL)?

Tidak selalu jelas di mana menggunakan indeks dalam tabel SQL. Namun ada beberapa aturan umum yang mungkin dapat membantu Anda memutuskan dalam banyak kasus.

  1. Menempatkan indeks pada kolom yang digunakan pada klausa where
  2. Letakkan indeks pada kolom yang Anda gunakan untuk bergabung.
  3. Cobalah untuk tidak menggunakan lebih dari 4-5 indeks pada kolom dalam tabel yang sama.

Dan konsep umum yang harus Anda ingat adalah:

  1. Indeks apa pun yang Anda gunakan akan membuat penelusuran di kolom tersebut lebih cepat.
  2. Indeks apa pun yang Anda tambahkan menyebabkan penyisipan ke tabel ini menjadi sedikit lebih lambat.
  3. Dari dua sebelumnya. Anda bertanggung jawab untuk memutuskan berapa banyak penyisipan dan kueri yang Anda lakukan pada tabel untuk memutuskan apakah akan menggunakan indeks dan pada kolom mana atau tidak.

EDIT

@AndrewLazarus komentar sangat penting dan saya memutuskan untuk menambahkannya ke jawaban:

  1. Jangan gunakan indeks pada kolom dengan hanya sedikit nilai yang berbeda. Misalnya, kolom yang menampung status, ketika hanya ada beberapa status, atau nilai boolean. Alasan untuk tidak melakukannya adalah karena indeks tidak terlalu membantu Anda karena hanya akan dibagi dengan jumlah nilai, dan karena Anda hanya memiliki sedikit, tidak akan ada manfaat nyata. Tabel akan menghabiskan lebih banyak ruang dengan indeks dan terbentuk lebih lambat saat penyisipan, tetapi Anda tidak akan mendapatkan kinerja yang lebih baik secara signifikan saat melakukan kueri


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Koneksi database PHP dan MYSQL dan pembuatan tabel hanya sekali

  2. Tabel MySQL dengan id utama AUTO_INCREMENT tidak merilis nomor setelah rollback

  3. cara membuat menu dinamis dengan submenu dengan php &mysql

  4. Bagaimana Anda mengubah jenis pemeriksaan untuk kolom MySQL?

  5. MYSQL UNION BERBEDA