Rumah > pangkalan data > tutorial mysql > Berapakah kos untuk mencipta, memadam dan menggunakan indeks Mysql?

Berapakah kos untuk mencipta, memadam dan menggunakan indeks Mysql?

王林
Lepaskan: 2023-06-03 15:55:03
ke hadapan
902 orang telah melayarinya

    1. Penciptaan dan pemadaman indeks dalam Mysql

    Enjin innodb dan myisam secara automatik akan mencipta indeks untuk kunci utama atau lajur dengan atribut UNIK.

    Jika anda ingin mengindeks lajur lain, anda perlu menunjukkannya secara eksplisit.

    1. Cipta indeks semasa membuat jadual

    CREATE TABLE 表名 (
        各个列的信息...,
        (KEY/INDEX) 索引名 (需要被索引的单个列或多个列)
    )
    Salin selepas log masuk

    Perhatikan bahawa sama ada KEY atau INDEX boleh digunakan sebagai sinonim.

    Contohnya, semasa membuat jadual index_demo, tambah indeks bersama untuk lajur c2 dan c3:

    CREATE TABLE index_demo(
        c1 INT,
        c2 INT,
        c3 CHAR(1),
        PRIMARY KEY(c1),
        INDEX idx_c2_c3 (c2, c3)
    );
    Salin selepas log masuk

    Nama indeks yang dibuat di sini ialah idx_c2_c3 Walaupun nama indeks boleh sewenang-wenangnya dinamakan, adalah disyorkan untuk menggunakan idx_ ialah awalan, diikuti dengan nama lajur indeks untuk disambung semula, dan berbilang lajur dipisahkan dengan garis bawah.

    2. Tambahkan indeks semasa mengubah suai struktur jadual

    ALTER TABLE 表名 ADD (KEY/INDEX) 索引名 (需要被索引的单个列或多个列);
    Salin selepas log masuk

    3 Padamkan indeks apabila mengubah suai struktur jadual

    ALTER TABLE 表名 DROP (KEY/INDEX) 索引名;
    Salin selepas log masuk

    Sekarang padamkan indeks idx_c2_c3 yang asalnya dibina, anda boleh menulis seperti ini:

    ALTER TABLE index_demo DROP INDEX idx_c2_c3;
    Salin selepas log masuk

    2 Kos pengindeksan

    Walaupun indeks adalah perkara yang baik, ia tidak boleh dibuat sewenang-wenangnya.

    1. Kos ruang

    Ini sangat jelas.

    • Setiap kali indeks dibuat, pokok B+ mesti dibina untuknya.

    • Setiap nod setiap pepohon B+ ialah halaman data, yang menggunakan 16kb ruang storan secara lalai.

    • Pokok B+ yang besar terdiri daripada banyak halaman data.

    Jadi, ini akan mengambil banyak ruang storan.

    2. Kos masa

    Memakan masa untuk mengekalkan jujukan

    Setiap kali menambah, memadam atau mengubah suai data dalam jadual, setiap indeks pepohon B+ perlu diubah suai.

    Kami tahu:

    • B+ Setiap tahap nod dalam pepohon membentuk senarai terpaut dua kali dalam tertib menaik bagi nilai lajur indeks.

    • Sama ada nod daun atau nod dalaman, rekod dalaman adalah mengikut tertib nilai lajur indeks, membentuk senarai terpaut tunggal.

    Oleh itu, apabila menambah, memadam atau mengubah suai operasi, ia boleh menyebabkan kerosakan pada pengisihan nod dan rekod Kemudian enjin storan memerlukan masa tambahan untuk melaksanakan operasi seperti pembahagian halaman dan kitar semula untuk mengekalkan Pengisihan nod dan rekod.

    Jika banyak indeks dicipta, anda boleh bayangkan bahawa pokok B+ yang sepadan dengan setiap indeks perlu menjalani operasi penyelenggaraan yang berkaitan, yang akan membawa banyak penggunaan.

    Analisis pelan pelaksanaan yang memakan masa

    Sebelum melaksanakan pernyataan pertanyaan, pelan pelaksanaan akan dijana terlebih dahulu.

    Secara umumnya, pernyataan pertanyaan menggunakan paling banyak satu indeks sekunder semasa pelaksanaan Apabila menjana pelan pelaksanaan, adalah perlu untuk mengira kos menggunakan indeks yang berbeza untuk melaksanakan pertanyaan, dan akhirnya memilih indeks terendah. Pertanyaan.

    Jika terlalu banyak indeks dicipta, ia mungkin mengambil masa terlalu lama untuk melaksanakan analisis kos, sekali gus menjejaskan prestasi pelaksanaan penyata pertanyaan.

    Atas ialah kandungan terperinci Berapakah kos untuk mencipta, memadam dan menggunakan indeks Mysql?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

    Label berkaitan:
    sumber:yisu.com
    Kenyataan Laman Web ini
    Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
    Tutorial Popular
    Lagi>
    Muat turun terkini
    Lagi>
    kesan web
    Kod sumber laman web
    Bahan laman web
    Templat hujung hadapan