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!