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 :

erreur dans ma page [PDO]


Sujet :

PHP & Base de données

  1. #1
    Membre du Club
    Inscrit en
    Février 2005
    Messages
    269
    Détails du profil
    Informations forums :
    Inscription : Février 2005
    Messages : 269
    Points : 62
    Points
    62
    Par défaut erreur dans ma page
    Bonsoir,
    voila je suis dans une impasse depuis quelques jours, mais je trouve pas d'explication.
    Il me dit que j'ai un index indefini! j'ai un message d'erreur quand je charge la page puis apres il ne revient plus.

    le probleme viens de cette ligne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $pdoStat->bindValue(':vendor', $_POST['vendor'], PDO::PARAM_STR);
    je vous remercie par avance.

    HB

    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
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    <?php
     
      /*****************************************
      *  Vérification du formulaire
      *****************************************/
      // Si le tableau $_POST existe alors le formulaire a été envoyé
      if(!empty($_POST))
      {
        // Une marque est-elle remplie ?
        if(empty($_POST['vendor']))
        {
          $message = 'Veuillez indiquer une marque svp !';
        }
      }
     
      $objectPDO = new PDO('mysql:host=localhost;dbname=multi-admin','root','');
     
      $pdoStat = $objectPDO->prepare('INSERT INTO marques VALUES (NULL, :vendor)');
     
      $pdoStat->bindValue(':vendor', $_POST['vendor'], PDO::PARAM_STR);
     
      $insertIsOk = $pdoStat->execute();
     
    ?>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" >
      <head>
        <link rel="stylesheet" href="css/style.css">
        <script src="script.js"></script>
        <title>Formulaire des Marques</title>
      </head>
      <body>
        <?php if(!empty($message)) : ?>
          <p><?php echo $message; ?></p>
        <?php endif; ?>
        <form action="<?php echo htmlspecialchars($_SERVER['REQUEST_URI'], ENT_QUOTES); ?>" method="post">
          <center>
            <fieldset>
              <legend>Marque</legend>
                <p>
                  <label for="vendor"></label>
                  <input type="text" name="vendor" id="vendor" value="<?php if(!empty($_POST['vendor'])) { echo htmlspecialchars($_POST['vendor'], ENT_QUOTES); } ?>" />
                </p>
                <p>
                  <input type="submit" name="submit" value="Inserer la marque" />
                </p>
            </fieldset>
          </center>
        </form>
      </body>
    </html>

  2. #2
    Membre émérite
    Avatar de badaze
    Homme Profil pro
    Chef de projets info
    Inscrit en
    Septembre 2002
    Messages
    1 412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets info
    Secteur : Transports

    Informations forums :
    Inscription : Septembre 2002
    Messages : 1 412
    Points : 2 522
    Points
    2 522
    Par défaut
    A quel champ est affectée la valeur NULL ? Est-ce que ce champ accepte le NULL ?
    Cela ne sert à rien d'optimiser quelque chose qui ne fonctionne pas.

    Mon site : www.emmella.fr

    Je recherche le manuel de l'Olivetti Logos 80B.

  3. #3
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Il ne faut pas faire l'insertion s'il n'y a pas de valeur :
    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(!empty($_POST))
      {
        // Une marque est-elle remplie ?
        if(empty($_POST['vendor']))
        {
          $message = 'Veuillez indiquer une marque svp !';
        } else {
      $objectPDO = new PDO('mysql:host=localhost;dbname=multi-admin','root','');
     
      $pdoStat = $objectPDO->prepare('INSERT INTO marques VALUES (NULL, :vendor)');
     
      $pdoStat->bindValue(':vendor', $_POST['vendor'], PDO::PARAM_STR);
     
      $insertIsOk = $pdoStat->execute();
       }
    }
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  4. #4
    Membre du Club
    Inscrit en
    Février 2005
    Messages
    269
    Détails du profil
    Informations forums :
    Inscription : Février 2005
    Messages : 269
    Points : 62
    Points
    62
    Par défaut
    Merci beaucoup, pour vos informations
    HB

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

Discussions similaires

  1. [jsp & Jdbc] Erreur dans ma page lors d'un delete
    Par critok dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 10/06/2008, 16h08
  2. Une erreur dans ma page
    Par misslol dans le forum Langage
    Réponses: 7
    Dernier message: 26/07/2007, 20h56
  3. Inserer la stack d'erreur dans une page JSP
    Par skunkies dans le forum Servlets/JSP
    Réponses: 7
    Dernier message: 25/09/2006, 17h10
  4. [jsp & Jdbc] Erreur dans ma page lors d'un delete
    Par critok dans le forum Servlets/JSP
    Réponses: 2
    Dernier message: 07/06/2006, 11h24

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