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

Mengapa MySQL Memerlukan Alias ​​untuk Semua Jadual Terbitan?

Mary-Kate Olsen
Lepaskan: 2024-12-15 09:46:11
asal
809 orang telah melayarinya

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
Salin selepas log masuk

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
Salin selepas log masuk

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!

sumber:php.cn
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan