Rumah >pangkalan data >tutorial mysql >Mengapa MySQL Memerlukan Alias ​​untuk Semua Jadual Terbitan?

Mengapa MySQL Memerlukan Alias ​​untuk Semua Jadual Terbitan?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-12-15 09:46:11812semak imbas

Why Does MySQL Require Aliases for All Derived Tables?

Memahami Ralat: "Setiap Jadual Terbitan Mesti Mempunyai Alias ​​Sendiri"

Apabila melaksanakan pertanyaan MySQL yang melibatkan jadual terbitan bersarang (sub- pertanyaan), ralat mungkin berlaku menyatakan "Setiap jadual terbitan mesti mempunyai alias sendiri." Ralat ini dicetuskan apabila sub-pertanyaan tidak diberikan alias unik.

Punca dan Penyelesaian:

Jadual terbitan dibuat dengan melampirkan sub-pertanyaan dalam kurungan. Untuk setiap jadual terbitan, MySQL memerlukan kemasukan alias, iaitu nama yang digunakan untuk merujuk kepada jadual dan datanya. Tujuan alias adalah untuk membezakan antara berbilang jadual terbitan dalam pertanyaan luar.

Untuk menyelesaikan ralat ini, tetapkan alias pada setiap sub-pertanyaan menggunakan kata kunci AS diikuti dengan nama unik:

SELECT ID FROM (
    SELECT ID, msisdn FROM (
        SELECT * FROM TT2
    ) AS TT2Subquery
) AS TableAlias

Dalam pertanyaan yang diubah suai ini, alias TT2Subquery diperuntukkan kepada sub-pertanyaan paling dalam dan TableAlias ​​ditugaskan kepada sub-pertanyaan luar. Alias ​​ini membenarkan MySQL membezakan antara dua sub-pertanyaan dan menyambungkannya dengan sewajarnya.

Sebagai alternatif, memandangkan sub-pertanyaan paling luar hanya mendapatkan satu lajur, ia boleh ditinggalkan sepenuhnya:

SELECT ID FROM TT2

Pertanyaan ringkas ini menghapuskan keperluan untuk sebarang alias sub-pertanyaan sambil mengekalkan hasil yang sama.

Atas ialah kandungan terperinci Mengapa MySQL Memerlukan Alias ​​untuk Semua Jadual Terbitan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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