IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

esayphp 1.8 et requête insert [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé Avatar de oceane751
    Profil pro
    Intégrateur Web
    Inscrit en
    Novembre 2004
    Messages
    1 280
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Intégrateur Web

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 280
    Par défaut esayphp 1.8 et requête insert
    bonjour à tous
    voilà j'ai une requete insert, qui insère bien dans la base de données mais j'ai une erreur que je ne comprends pas trop que voici :
    Warning: mysql_affected_rows(): supplied argument is not a valid MySQL-Link resource in c:\program files\easyphp1-8\www....
    et voici ma requete :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
     
    if ($animal > 0)
    {
      if ($add_ani = mysql_query ("INSERT into comprendre (num_reservation, id_supp, quantite)
      VALUES (".$num_com.", ".$rowani[0].", ".$animal.")"))
       {
      $rowaddani = mysql_affected_rows($add_ani);
     
      echo "requete add_animal OK";
    }
     
    else
    {
     echo "REQUETE PAS BONNE";
    }
    }
    merci pour votre aide

  2. #2
    Membre Expert
    Avatar de Nesmontou
    Homme Profil pro
    Architecte logiciel
    Inscrit en
    Septembre 2004
    Messages
    1 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Architecte logiciel
    Secteur : Finance

    Informations forums :
    Inscription : Septembre 2004
    Messages : 1 612
    Par défaut
    Salut, cette erreur signifie que ta requête est incorrecte. Quand tu as une erreur comme ça, il faut :
    - aficher la requête
    - l'éxécuter dans PhpMyAdmin (par exemple)
    - si ça marche, c'est OK. Sinon, la modifier jusqu'à ce que ça marche
    - l'insérer dans ton script

    Dans ton cas, tu peux faire (en gros)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    if ($animal > 0) {
      $sql = 'INSERT into comprendre (num_reservation, id_supp, quantite) VALUES ('.$num_com.', '.$rowani[0].', \''.$animal.'\')';
      echo $sql; // pour visualiser la requête
      $add_ani = mysql_query($sql)
      if ($add_ani === FALSE) { 
        $rowaddani = mysql_affected_rows($add_ani); 
        echo "requete add_animal OK";
      } 
    else {
      echo "REQUETE PAS BONNE"; 
      }
    }
    Ne pas oublier que si tes champs sont de types numérique, il ne faut pas mettre de guillements simples lors de l'insertion, par contre si ton champs a un autre type, il faut en mettre

    Tu peux aussi faire un tour ici : http://fr2.php.net/manual/fr/function.mysql-query.php, l'exemple 1 ressemble à ce que tu veux faire et jeter un oeil ici : http://php.developpez.com/faq/?page=...ysql_ressource

    Bon développement

  3. #3
    Membre éprouvé Avatar de oceane751
    Profil pro
    Intégrateur Web
    Inscrit en
    Novembre 2004
    Messages
    1 280
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Intégrateur Web

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 280
    Par défaut
    oui mais ma requete elle s'insere bien dans ma base de données

    en fait je fais cette insertion en fonction du nombre d'animal choisi précédement par l'utilisateur (soit $animal)
    donc si le $animal est superieur à 0, on insère dans la base de données.
    le test, si l'utilisateur ne choisit pas d'animal, a été fait, et rien ne s'insère dans la BDD, ce qui est tout à fait normal.

    donc je pensais que cette erreur était du à easyphp 1.8, c'est pour cela que je posais la question

    mais l'erreur est toujours là

  4. #4
    Membre éprouvé Avatar de oceane751
    Profil pro
    Intégrateur Web
    Inscrit en
    Novembre 2004
    Messages
    1 280
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Intégrateur Web

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 280
    Par défaut
    je viens d'essayer ton code proposé, et il n'y a plus l'erreur

    INSERT into comprendre (num_reservation, id_supp, quantite) VALUES (12, 2, '1')REQUETE PAS BONNE

    j'ai dejà fait des requetes d'insertion et j'ai jamais eut besoin de mettre :
    if ($add_ani === FALSE)

    j'ai lu que si la requete n'est pas bonne ça retourne FALSE

    je comprends pas pourquoi il faut mettre ===FALSE

    :

  5. #5
    Membre Expert
    Avatar de ska_root
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2005
    Messages
    1 203
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Service public

    Informations forums :
    Inscription : Août 2005
    Messages : 1 203
    Par défaut
    dans php, la constante true est égale à 1 et false à 0, si mysql_affected_rows retourne 0, ce n'est pas la même chose que de signaler une erreur dans l'exploitation de la fonction

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
       // imaginons une requete qui ne trouve pas le id 2
       $res=mysql_query("UPDATE table SET truc = 'machin' WHERE id=2");
     
       if(mysql_affected_rows($res) == 0) echo "Erreur dans la requete";
       // hors le resultat est de 0 enregistrement d'accord, mais la requete est bonne donc pas de raison d'afficher le message erreur de requete
     
       if(mysql_affected_rows($res) === 0) echo "Erreur dans la requete";
       // la rien ne s'affiche...
    voila la différence

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [VBA] difficultés avec une requête INSERT
    Par elias dans le forum Access
    Réponses: 7
    Dernier message: 06/09/2005, 14h53
  2. requête insert
    Par mattoo dans le forum Langage SQL
    Réponses: 10
    Dernier message: 20/04/2005, 14h09
  3. Réponses: 4
    Dernier message: 05/04/2005, 18h28
  4. probleme requête insert.... where
    Par Amandine62 dans le forum Langage SQL
    Réponses: 7
    Dernier message: 21/02/2005, 14h26
  5. Problème sur une requête INSERT
    Par Marion dans le forum Langage SQL
    Réponses: 3
    Dernier message: 17/06/2003, 08h45

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo