Mengapakah saya mendapat Ralat \'Column Count Doesn't Match Value Count at Row 1\' dalam Kod PHP dan MySQL saya?

Barbara Streisand
Lepaskan: 2024-10-27 11:23:01
asal
753 orang telah melayarinya

Why am I getting the

Membetulkan "Column Count Doesn't Match Value Count at Row 1" Ralat dalam PHP dan MySQL

Apabila cuba memasukkan data ke dalam Pangkalan data MySQL menggunakan PHP, anda mungkin menghadapi ralat berikut:

Column count doesn't match value count at row 1
Salin selepas log masuk

Ralat ini berlaku apabila bilangan nilai yang disediakan dalam pertanyaan INSERT tidak sepadan dengan bilangan lajur yang ditakrifkan dalam jadual sasaran.

Memahami Punca

Dalam kod contoh anda, anda telah menetapkan 9 lajur dalam pertanyaan INSERT:

INSERT INTO dbname (id, Name, Description, shortDescription, Ingredients, Method, Length, dateAdded, Username)
Salin selepas log masuk

Walau bagaimanapun, anda hanya menyediakan 8 nilai :

sprintf("INSERT INTO dbname (id, Name, Description, shortDescription, Ingredients, Method, Length, dateAdded, Username) VALUES ('', '%s', '%s', '%s', '%s', '%s', '%s', '%s')",
    mysql_real_escape_string($name),
    mysql_real_escape_string($description),
    mysql_real_escape_string($shortDescription),
    mysql_real_escape_string($ingredients),
    //mysql_real_escape_string($image),
    mysql_real_escape_string($length),
    mysql_real_escape_string($dateAdded),
    mysql_real_escape_string($username));
Salin selepas log masuk

Akibatnya, MySQL tidak dapat memadankan bilangan nilai yang diberikan kepada lajur yang ditentukan, membawa kepada ralat.

Penyelesaian: Pastikan Kiraan Nilai Padan dengan Lajur Kira

Untuk menyelesaikan isu, anda perlu memastikan bahawa bilangan nilai dalam pertanyaan anda sepadan dengan bilangan lajur dalam jadual sasaran. Dalam kes ini, anda telah terlepas memberikan nilai Kaedah.

Ubah suai kod anda untuk memasukkan nilai yang tiada:

$query = sprintf("INSERT INTO dbname (id, Name, Description, shortDescription, Ingredients, Method, Length, dateAdded, Username) VALUES ('', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s')",
    mysql_real_escape_string($name),
    mysql_real_escape_string($description),
    mysql_real_escape_string($shortDescription),
    mysql_real_escape_string($ingredients),
    mysql_real_escape_string($method),
    mysql_real_escape_string($length),
    mysql_real_escape_string($dateAdded),
    mysql_real_escape_string($username));
Salin selepas log masuk

Dengan memberikan bilangan nilai yang betul, anda akan berjaya melakukannya masukkan data ke dalam pangkalan data MySQL tanpa menghadapi ralat ketidakpadanan kiraan lajur.

Atas ialah kandungan terperinci Mengapakah saya mendapat Ralat \'Column Count Doesn't Match Value Count at Row 1\' dalam Kod PHP dan MySQL saya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!