Masalah menggunakan ANSI JOIN bercampur dan jadual dipisahkan koma dalam pertanyaan MySQL
Anda mungkin menghadapi ralat "Lajur tidak diketahui" apabila mencampurkan sintaks ANSI JOIN (INNER JOIN, CROSS JOIN, LEFT JOIN) dan rujukan jadual yang dipisahkan koma dalam pertanyaan MySQL. Ralat ini berlaku kerana tafsiran MySQL terhadap pengendali koma bergantung pada kedudukannya.
Soalan:
Pertimbangkan pertanyaan berikut:
<code class="language-sql">SELECT m.*, t.* FROM memebers as m, telephone as t INNER JOIN memeberFunctions as mf ON m.id = mf.memeber INNER JOIN mitgliedTelephone as mt ON m.id = mt.memeber WHERE mf.function = 32</code>
Pertanyaan ini menghasilkan ralat "Lajur tidak diketahui 'm.id' dalam 'pada klausa'".
Penyelesaian:
Untuk menyelesaikan ralat ini, elakkan mencampurkan sintaks ANSI JOIN dengan jadual dipisahkan koma. Gunakan sintaks ANSI JOIN sahaja, seperti yang ditunjukkan dalam pertanyaan yang diubah suai di bawah:
<code class="language-sql">SELECT m.*, t.* FROM memebers as m JOIN telephone as t ON 1=1 INNER JOIN memeberFunctions as mf ON m.id = mf.memeber AND mf.function = 32 INNER JOIN mitgliedTelephone as mt ON m.id = mt.memeber</code>
Penjelasan:
MySQL kini mentafsirkan pertanyaan sebagai:
<code class="language-sql">((memembers as m JOIN telephone as t ON 1=1) INNER JOIN memeberFunctions as mf ON m.id = mf.memeber) INNER JOIN mitgliedTelephone as mt ON m.id = mt.memeber</code>
Dalam sintaks ini, operan klausa JOIN ditakrifkan dengan jelas dan lajur "m.id" dirujuk dengan betul dalam klausa ON. ON 1=1
ditambah untuk memastikan ketepatan operasi JOIN
, kerana kata kunci JOIN
memerlukan klausa ON
.
Nota:
Adalah penting untuk ambil perhatian bahawa menggunakan koma untuk memisahkan jadual tidak lagi dianggap sebagai amalan terbaik dalam MySQL. Adalah disyorkan untuk menggunakan sintaks ANSI JOIN untuk memastikan kejelasan dan mengelakkan kemungkinan ralat.
Atas ialah kandungan terperinci Mengapa Mencampurkan ANSI JOIN dan Jadual Dipisahkan Koma dalam MySQL Membawa kepada Ralat 'Lajur Tidak Diketahui'?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!