Tajuk: Lajur 'column_name' dalam 'on clause' - Cara menyelesaikan ralat MySQL: Lajur tidak diketahui dalam klausa, contoh kod khusus diperlukan
Teks artikel:
MySQL ialah pangkalan data hubungan sumber terbuka yang biasa digunakan Sistem pengurusan digunakan secara meluas dalam pelbagai jenis pembangunan aplikasi. Walau bagaimanapun, dalam proses menggunakan MySQL, anda kadangkala menghadapi pelbagai ralat dan masalah Salah satu ralat biasa ialah "Lajur 'column_name' dalam 'on clause'" (lajur tidak diketahui dalam klausa on).
Apabila kami melaksanakan pernyataan join query (JOIN) dalam MySQL dan nama lajur yang tidak diketahui dirujuk dalam klausa on, MySQL akan melaporkan ralat ini. Ralat ini biasanya disebabkan oleh salah ejaan nama lajur, nama lajur yang tidak ditakrifkan dalam jadual yang sepadan atau penggunaan alias yang salah.
Jadi, bagaimana untuk menyelesaikan masalah ini? Berikut ialah beberapa penyelesaian biasa:
Sebagai contoh, katakan kita mempunyai jadual yang dipanggil "pengguna" yang mengandungi lajur bernama "id" dan "nama". Ralat ini akan dilaporkan jika kami mengeja nama lajur "id" sebagai "Id" dalam pertanyaan sertai. Cara yang betul untuk menulisnya ialah menukar nama lajur "id" kepada "Id".
PILIH *
DARI pengguna
SERTAI pesanan PADA pengguna.Id = orders.user_id;
Cara yang betul untuk menulisnya ialah:
PILIH *
DARI pengguna
SERTAI pesanan PADA users.id = orders.user_id;
DARI pengguna
SERTAI pesanan PADA users.id = orders.customer_id;
DARI pengguna
SERTAI pesanan PADA users.id = pesanan.user
PILIH *
DARI pengguna AS uSERTAI pesanan AS o ON u.id = orders.user_id;
Pada ketika ini, rujuk lajur dalam pada klausa Apabila menamakan, kita harus menggunakan awalan alias yang betul "u" dan bukannya nama jadual asal "pengguna".
Melalui kaedah di atas, kita boleh menyelesaikan masalah ralat MySQL "Unknown column 'column_name' in 'on clause'" (unknown column in the on clause). Pada masa yang sama, untuk lebih memahami ralat ini dan penyelesaiannya, contoh kod khusus diberikan di bawah:
Kod contoh:
CREATE TABLE pengguna (
id INT PRIMARY KEY, name VARCHAR(50)
); . MASUKKAN KE DALAM pesanan NILAI (1, 1, '2022-01-01');
MASUKKAN KE DALAM pesanan NILAI (2, 2, '2022-01-02');
DARI pengguna
SERTAI pesanan PADA pengguna. id = orders.user_id;
Dalam contoh ini, kami mencipta jadual bernama "pengguna" dan jadual bernama "pesanan", dan ia disambungkan dengan ID pengguna. Dalam pertanyaan sertai, kami menggunakan nama lajur dan awalan alias yang betul untuk mengelakkan ralat.
Atas ialah kandungan terperinci Lajur tidak diketahui 'column_name' dalam 'on clause' - Bagaimana untuk menyelesaikan ralat MySQL: lajur tidak diketahui dalam klausa. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!