Rumah >pangkalan data >tutorial mysql >Mengapa Mencampurkan ANSI JOIN dan Jadual Dipisahkan Koma dalam MySQL Membawa kepada Ralat 'Lajur Tidak Diketahui'?

Mengapa Mencampurkan ANSI JOIN dan Jadual Dipisahkan Koma dalam MySQL Membawa kepada Ralat 'Lajur Tidak Diketahui'?

Linda Hamilton
Linda Hamiltonasal
2025-01-09 10:57:41538semak imbas

Why Does Mixing ANSI JOINs and Comma-Separated Tables in MySQL Lead to

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!

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