


Lajur tidak diketahui 'column_name' dalam 'on clause' - Bagaimana untuk menyelesaikan ralat MySQL: lajur tidak diketahui dalam klausa
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:
- 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.
DARI pengguna
SERTAI pesanan PADA users.id = orders.customer_id;
DARI pengguna
SERTAI pesanan PADA users.id = pesanan.user
- Sebagai contoh, katakan kami menggunakan alias jadual untuk memudahkan kod:
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!

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

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 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.

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.

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.

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

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.

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*.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

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

Artikel Panas

Alat panas

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
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

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 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.
