Maison >développement back-end >tutoriel php >Pourquoi est-ce que j'obtiens l'erreur « Le nombre de colonnes ne correspond pas au nombre de valeurs à la ligne 1 » dans mon instruction PHP MySQL INSERT ?

Pourquoi est-ce que j'obtiens l'erreur « Le nombre de colonnes ne correspond pas au nombre de valeurs à la ligne 1 » dans mon instruction PHP MySQL INSERT ?

Barbara Streisand
Barbara Streisandoriginal
2024-10-26 18:57:301040parcourir

Why Am I Getting

Erreur PHP, MySQL : le nombre de colonnes ne correspond pas au nombre de valeurs à la ligne 1 résolu

Lorsque vous rencontrez l'erreur « Le nombre de colonnes ne correspond pas ne correspond pas au nombre de valeurs à la ligne 1", cela indique un écart entre le nombre de colonnes dans une table de base de données et le nombre de valeurs fournies dans une instruction INSERT.

Dans l'extrait de code fourni :

<code class="php">// ...

$query = 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)
);

// ...</code>

Vous avez spécifié 9 colonnes dans l'instruction INSERT, mais seules 8 valeurs sont fournies. Plus précisément, il vous manque la valeur de la colonne « Méthode ».

Pour résoudre le problème, vous devez ajouter la valeur de la méthode à l'instruction INSERT :

<code class="php">// ...

$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)
);

// ...</code>

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn