Rumah  >  Artikel  >  pangkalan data  >  Apakah yang dimaksudkan dengan pulangan jadual MySQL?

Apakah yang dimaksudkan dengan pulangan jadual MySQL?

王林
王林ke hadapan
2023-06-01 22:46:043124semak imbas

Pengenalan

Ringkasnya, pulangan jadual bermakna MySQL mesti menanyakan indeks kunci utama dahulu, dan kemudian menggunakan indeks kunci utama untuk mencari data.

Di bawah, beberapa soalan dianalisis dan dijawab:

  • Apakah itu indeks berkelompok? Apakah indeks bukan berkelompok?

  • Mengapa kita perlu mencari indeks kunci utama dahulu apabila mengembalikan jadual?

  • Apakah perbezaan antara indeks kunci utama dan indeks bukan kunci utama?

  • Bagaimana untuk mengelakkan pemulangan borang?

Apakah itu indeks berkelompok dan indeks tidak berkelompok?

Indeks MySQL dikelaskan daripada perspektif yang berbeza, seperti: mengikut struktur data, mengikut perspektif logik dan oleh storan fizikal.

Antaranya, terdapat dua jenis indeks mengikut storan fizikal: indeks berkelompok dan indeks bukan berkelompok .

Ringkasnya, indeks berkelompok ialah indeks kunci utama .

Di luar indeks kunci utama ialah indeks bukan berkelompok juga dipanggil indeks tambahan atau indeks sekunder.

Apakah perbezaan antara indeks kunci utama dan indeks kunci bukan utama?

Mata yang sama: Kedua-duanya menggunakan B+Tree.

Perbezaan: Nod daun menyimpan data berbeza

  • Nod daun menyimpan indeks kunci utama baris data lengkap;

  • Nod daun bagi indeks bukan kunci utama menyimpan nilai kunci utama. Nod daun tidak mengandungi semua data rekod Selain kunci yang digunakan untuk mengisih, nod daun bukan kunci utama juga mengandungi penanda buku (penanda halaman), yang menyimpan kunci indeks berkelompok.

Jadi apakah perbezaan dalam penggunaan kedua-dua indeks ini?

Pertanyaan menggunakan indeks kunci primer:

# 主键索引的的叶子节点存储的是**一行完整的数据**,
# 所以只需搜索主键索引的 B+Tree 就可以轻松找到全部数据
select * from user where id = 1;

Pertanyaan menggunakan indeks bukan kunci utama:

rreee

Ia boleh dilihat bahawa indeks bukan kunci utama digunakan Gunakan B+Tree sekali lagi daripada indeks kunci primer.

Pemahaman mudah tentang B-Tree dan B+Tree

Kunci untuk memahami indeks berkelompok dan indeks tidak berkelompok terletak pada pemahaman B+Tree.

Gunakan gambar untuk mewakilinya dan saya tidak akan menerangkan yang lain terlalu banyak:

Apakah yang dimaksudkan dengan pulangan jadual MySQL?

Ini mudah sahaja Mari perkenalkan perbezaan antara B-Tree dan B+Tree:

  • Dalam pokok B+, hanya nod daun mempunyai penunjuk kepada rekod, manakala dalam B-tree, semua nod mempunyai , item indeks yang muncul dalam nod dalaman tidak lagi akan muncul dalam nod daun.

  • Semua nod daun dalam pokok B+ disambungkan bersama melalui penunjuk, tetapi tidak dalam pokok B.

Bagaimana untuk mengelakkan pemulangan borang?

Gunakan indeks penutup Apa yang dipanggil indeks penutup bermakna indeks mengandungi semua medan dalam pertanyaan dalam kes ini, tidak perlu melakukan pertanyaan kembali ke jadual.

Atas ialah kandungan terperinci Apakah yang dimaksudkan dengan pulangan jadual MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:yisu.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam