cari
Rumahpangkalan datatutorial mysqlLajur tidak diketahui 'column_name' dalam 'on clause' - Bagaimana untuk menyelesaikan ralat MySQL: lajur tidak diketahui dalam klausa

Lajur tidak diketahui 'column_name' dalam 'on clause' - Bagaimana untuk menyelesaikan ralat MySQL: lajur tidak diketahui dalam klausa

Oct 05, 2023 am 08:13 AM
Selesaikan ralat mysql:Ralat nama lajurLajur tidak diketahui dalam klausapengendalian ralat mysql

Unknown column 'column_name' in 'on clause' - 如何解决MySQL报错:on子句中的未知列

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:

  1. Sahkan sama ada nama lajur dieja dengan betul: Pertama, kita harus menyemak dengan teliti sama ada nama lajur dalam kod dieja secara konsisten dengan nama lajur dalam jadual pangkalan data, dengan memberi perhatian kepada sama ada kes itu sepadan . Jika ia tidak konsisten, anda perlu mengubah suai nama lajur dalam kod kepada ejaan yang betul.

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;

    Sahkan lajur Sama ada nama ditakrifkan dalam jadual yang betul: Jika kami mengesahkan bahawa ejaan nama lajur adalah betul, kami perlu memastikan bahawa ia ditakrifkan dalam jadual yang sepadan. Begitu juga, semak semula sama ada nama jadual dan lajur sepadan dengan takrifan dalam pangkalan data.
Sebagai contoh, katakan kita mempunyai jadual yang dipanggil "pesanan" yang mengandungi lajur bernama "id_pengguna". Tetapi jika kami menulis nama lajur "user_id" sebagai "customer_id" dalam pertanyaan sambungan, ralat ini akan dilaporkan. Pada masa ini, kita perlu mengubah suai nama lajur kepada ejaan yang betul.

PILIH *

DARI pengguna
SERTAI pesanan PADA users.id = orders.customer_id;

Cara yang betul untuk menulisnya ialah:

PILIH *

DARI pengguna
SERTAI pesanan PADA users.id = pesanan.user

Gunakan jadual Berhati-hati dengan petikan semasa mengalias: Kadangkala, alias jadual digunakan dalam pertanyaan gabungan untuk memudahkan kod. Walau bagaimanapun, apabila menggunakan alias jadual, ralat ini juga boleh berlaku jika awalan alias tidak digunakan dengan betul apabila merujuk nama lajur dalam klausa on.
  1. Sebagai contoh, katakan kami menggunakan alias jadual untuk memudahkan kod:

PILIH *

DARI pengguna AS u

SERTAI 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');

PILIH *

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.

Ringkasnya, untuk menyelesaikan ralat MySQL "Lajur 'column_name' tidak diketahui dalam 'pada klausa'", anda perlu memberi perhatian kepada ejaan nama lajur, sama ada nama lajur telah ditakrifkan dalam jadual, dan kaedah rujukan apabila menggunakan alias. Dengan menyemak dan mengubah suai kod dengan teliti dengan betul, kami boleh mengelakkan ralat ini dan berjaya melaksanakan pernyataan pertanyaan gabungan.

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!

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
Apakah perbezaan sintaks antara MySQL dan dialek SQL yang lain?Apakah perbezaan sintaks antara MySQL dan dialek SQL yang lain?Apr 27, 2025 am 12:26 AM

Mysqldiffersfromothersqldialectsyntaxforlimit, auto-increment, stringcomparison, subqueries, andperformanceanalysis.1) mySqlusSlimit, whilesqlserverestopandoracleusesusesrownum.2)

Apakah pemisahan MySQL?Apakah pemisahan MySQL?Apr 27, 2025 am 12:23 AM

Pemisahan MySQL meningkatkan prestasi dan memudahkan penyelenggaraan. 1) Bahagikan jadual besar ke dalam kepingan kecil dengan kriteria tertentu (seperti julat tarikh), 2) secara fizikal membahagikan data ke dalam fail bebas, 3) MystQL boleh memberi tumpuan kepada partisi yang berkaitan apabila pertanyaan, 4) Pengoptimal pertanyaan boleh melangkau partisi yang tidak berkaitan, 5) Memilih strategi partisi yang tepat dan mengekalkannya secara tetap adalah kunci.

Bagaimana anda memberikan dan membatalkan keistimewaan di MySQL?Bagaimana anda memberikan dan membatalkan keistimewaan di MySQL?Apr 27, 2025 am 12:21 AM

Bagaimana untuk memberikan dan membatalkan keizinan di MySQL? 1. Gunakan pernyataan geran untuk memberikan kebenaran, seperti GrantallPrivileGeSondatabase_name.to'username'@'host '; 2. Gunakan pernyataan membatalkan untuk membatalkan kebenaran, seperti RevokeAllPrivileGeSondatabase_name.from'username'@'host 'untuk memastikan komunikasi tepat pada masanya perubahan kebenaran.

Terangkan perbezaan antara enjin penyimpanan InnoDB dan myisam.Terangkan perbezaan antara enjin penyimpanan InnoDB dan myisam.Apr 27, 2025 am 12:20 AM

InnoDB sesuai untuk aplikasi yang memerlukan sokongan transaksi dan kesesuaian yang tinggi, sementara myisam sesuai untuk aplikasi yang memerlukan lebih banyak bacaan dan kurang menulis. 1.InnoDB menyokong kunci transaksi dan peringkat bank, sesuai untuk sistem e-dagang dan perbankan. 2.Myisam menyediakan bacaan dan pengindeksan yang cepat, sesuai untuk sistem pengurusan blog dan kandungan.

Apakah pelbagai jenis gabungan dalam MySQL?Apakah pelbagai jenis gabungan dalam MySQL?Apr 27, 2025 am 12:13 AM

Terdapat empat jenis utama dalam MySQL: innerjoin, leftjoin, rightjoin dan fullouterjoin. 1.InnerJoin Mengembalikan semua baris dalam dua jadual yang memenuhi syarat gabungan. 2.LeftJoin Mengembalikan semua baris di meja kiri, walaupun tidak ada baris yang sepadan di meja yang betul. 3. Rightjoin bertentangan dengan leftjoin dan mengembalikan semua baris di meja kanan. 4.FullouterJoin Mengembalikan semua baris dalam dua jadual yang memenuhi atau tidak memenuhi syarat gabungan.

Apakah enjin penyimpanan yang berbeza di MySQL?Apakah enjin penyimpanan yang berbeza di MySQL?Apr 26, 2025 am 12:27 AM

MysqloffersvariousstorageEngines, eachSuitedfordifferentusecases: 1) innodbisidealforapplicationsNeedingacidcomplianceandhighconcurrency, supportingtransactionsandforeignkeys.2) myisamisbestforread-heavyworkloads, lacktransactive.2)

Apakah beberapa kelemahan keselamatan biasa di MySQL?Apakah beberapa kelemahan keselamatan biasa di MySQL?Apr 26, 2025 am 12:27 AM

Kelemahan keselamatan biasa dalam MySQL termasuk suntikan SQL, kata laluan yang lemah, konfigurasi kebenaran yang tidak betul, dan perisian yang tidak dimulakan. 1. Suntikan SQL boleh dicegah dengan menggunakan pernyataan pra -proses. 2. Kata laluan yang lemah boleh dielakkan dengan secara paksa menggunakan strategi kata laluan yang kuat. 3. 4. Perisian yang tidak ditetapkan boleh ditampal dengan kerap memeriksa dan mengemas kini versi MySQL.

Bagaimanakah anda dapat mengenal pasti pertanyaan perlahan di MySQL?Bagaimanakah anda dapat mengenal pasti pertanyaan perlahan di MySQL?Apr 26, 2025 am 12:15 AM

Mengenal pasti pertanyaan perlahan dalam MySQL boleh dicapai dengan membolehkan log pertanyaan perlahan dan menetapkan ambang. 1. Dayakan log pertanyaan perlahan dan tetapkan ambang. 2. Lihat dan menganalisis fail log pertanyaan perlahan, dan gunakan alat seperti mysqldumpslow atau pt-que-digest untuk analisis mendalam. 3. Mengoptimumkan pertanyaan perlahan dapat dicapai melalui pengoptimuman indeks, penulisan pertanyaan dan mengelakkan penggunaan pilih*.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

mPDF

mPDF

mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.