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 :

Formulaire PHP SQL table inexistante [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre du Club Avatar de IamKanagawa
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2018
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2018
    Messages : 114
    Points : 54
    Points
    54
    Par défaut Formulaire PHP SQL table inexistante
    Bonjour j'ai un formulaire mais il ne trouve pas ma premiere table pouvez vous m'aidez

    Quand je saisis mes information et que je clique sur valider il m'affiche le message suivant :



    Catched exception at line 5 : SQLSTATE[42S22]: Column not found: 1054 Unknown column 'matricule_employe' in 'field list'



    Donc il ne trouve pas ma premiere table 'matricule_employe' qui sert d'identifiant ^^

    HTML Formulaire :

    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
    <p class="contact"> <label><u>Saisir le <b>Nom :</b></u></label></p>
    <input type="text" placeholder="Nom du salarié" name="nom_employe"><br/>
     
    <p class="contact"><label class="txt2"><u> Saisir le <b>Prenom :</b></u></label></p>
    <input type="text" placeholder="Prénom du salarié" name="prenom_employe"></label><br/>
     
    <p class="contact"><label class="txt2"><u> Saisir la <b>Date de naissance :</b></u></label></p>
    <input type="date" placeholder="Date de naissance du salarié" name="datenaiss_employe"><br/>
     
    <p class="contact"><label class="txt2"><u>Saisir la <b>Date d'entrée dans l'entreprise :</b></u></label></p>
    <input type="date" placeholder="Date d'entrée dans l'entreprise" name="date_embauche_employe"><br/>
     
    <p class="contact"><label class="txt2" for="photo_employe"><u>Fichier <b> Photo de profil</b> (PDF, PNG, JPG |max. 1 Mo):</u></label></p>
    <input type="file" name="photo_employe" id="photoprofil"><br/>
     
    <p class="contact"><label class="txt2"><u> Saisir le <b>Contrat :</b></u></label></p>
    <select name="contrat_employe">
    <option value="CDI">CDI</option>
    </select><br/>
    <p class="contact"><label class="txt2"><u> Saisir la <b>Fonction :</b></u></label></p>
    <select name="fonction_employe">
    <optgroup label="Cadre">
    <option value="responsable">Responsable </option>
    </optgroup>
    </select> <br/>
     
    <p class="contact"><label class="txt2"><u> Saisir le <b>Statut :</b></u> </label></p>
    <select name="statut_employe">
    <option value="cadre">Cadre</option>
    </select><br/>
     
    <p class="contact"><label class="txt2" for="carte_identite_employe"><u>Fichier <b>carte d'identité </b>(PDF, PNG, JPG |max. 1 Mo):</u></label></p>
    <input type="file" name="carte_identite_employe" id="carteidentite"><br/>
     
    <p class="contact"><label class="txt2" for="carte_btp_employe"><u>Fichier <b>carte identification professionnelle BTP </b>(PDF, PNG, JPG |max. 1 Mo)(Que pour les ouvriers):</u></label></p>
    <input type="file" name="carte_btp_employe" id="carteBTP">
     
    </br><label class="contact"> <input type="submit" value="Valider" name="Valider" action=""></label><br/>
    <label class="contact"> <input type="reset" value="Réinitialiser" name="Réinitialiser" action=""></label><br/>
    </form>
    </fieldset>
    </div>
    PHP traitement
    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
    <?php
    include 'connect_bdd.php';
    if (isset ($_POST['Valider'])){
    $matricule_employe=$_POST['matricule_employe'];
    $nom_employe=$_POST['nom_employe'];
    $prenom_employe=$_POST['datenaiss_employe'];
    $datenaiss_employe=$_POST['nom_employe'];
    $date_embauche_employe=$_POST['date_embauche_employe'];
    $photo_employe=$_POST['photo_employe'];
    $contrat_employe=$_POST['contrat_employe'];
    $fonction_employe=$_POST['fonction_employe'];
    $statut_employe=$_POST['statut_employe'];
    $carte_identite_employe=$_POST['carte_identite_employe'];
    $carte_btp_employe=$_POST['carte_btp_employe'];
    $pdo -> exec ("INSERT INTO employe_table (matricule_employe, nom_employe, prenom_employe, datenaiss_employe, date_embauche_employe, photo_employe, contrat_employe, fonction_employe, statut_employe, carte_identite_employe, carte_btp_employe)
    VALUES('$matricule_employe','$nom_employe', '$prenom_employe', '$datenaiss_employe', '$date_embauche_employe','$photo_employe', ;'$contrat_employe', '$fonction_employe,'$statut_employe','$carte_identite_employe','$carte_btp_employe')");
    }
    ?>
    connect bdd

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    <?php
    try
    {
    $pdo = new PDO('mysql:host=localhost;dbname=bdd', 'root', 'root', array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION ));
    $stmt = $pdo->query('SELECT matricule_employe, nom_employe, prenom_employe, datenaiss_employe, date_embauche_employe, photo_employe, contrat_employe, fonction_employe, statut_employe, carte_identite_employe, carte_btp_employe ');
    $messages = $stmt->fetchAll(PDO::FETCH_OBJ);
    }
    catch(Exception $e)
    {
    exit('<b>Catched exception at line '. $e->getLine() .' :</b> '. $e->getMessage());
    }
    ?>
    Merci pour ttes vos futur réponses
    Il faut se tromper dans la vie, pour apprendre et s'améliorer.

    Etudiant BTS-SIO option SLAM

  2. #2
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Bonjour et Bienvenu sur DVP.

    1- Dans ton select, tu n'as pas la clause from employe_table, d'autant plus que cette requête est inutile, surtout dans un fichier de configuration.
    2- Utilise une requête préparée au lieu de passer les valeurs directement dans la requête.

    A+.

  3. #3
    Membre du Club Avatar de IamKanagawa
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2018
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2018
    Messages : 114
    Points : 54
    Points
    54
    Par défaut Bonjour et merci de me répondre ^^
    Voila le code avec votre modification :
    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
    <?php
    include 'connect_bdd.php';
     
    if (isset ($_POST['Valider'])){
        $matricule_employe=$_POST['matricule_employe'];
        $nom_employe=$_POST['nom_employe'];
        $prenom_employe=$_POST['datenaiss_employe'];
        $datenaiss_employe=$_POST['nom_employe'];
        $date_embauche_employe=$_POST['date_embauche_employe'];
        $photo_employe=$_POST['photo_employe'];
        $contrat_employe=$_POST['contrat_employe'];
        $fonction_employe=$_POST['fonction_employe'];
        $statut_employe=$_POST['statut_employe'];
        $carte_identite_employe=$_POST['carte_identite_employe'];
        $carte_btp_employe=$_POST['carte_btp_employe'];
        $pdo -> exec ("INSERT INTO From employe_table (matricule_employe, nom_employe, prenom_employe, datenaiss_employe, date_embauche_employe, photo_employe, contrat_employe, fonction_employe, statut_employe, carte_identite_employe, carte_btp_employe)
        VALUES('$matricule_employe','$nom_employe', '$prenom_employe', '$datenaiss_employe', '$date_embauche_employe','$photo_employe', ;'$contrat_employe', '$fonction_employe,'$statut_employe','$carte_identite_employe','$carte_btp_employe')");
    }
    ?>
    malheureusement aucun changement

    voici un screen de ma table
    Images attachées Images attachées  
    Il faut se tromper dans la vie, pour apprendre et s'améliorer.

    Etudiant BTS-SIO option SLAM

  4. #4
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Ta requête insert est bonne, vire le from de là. Je parle de cette requête qui devait avoir un clause from, et que cette requête ne sert à rien:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $stmt = $pdo->query('SELECT matricule_employe, nom_employe, prenom_employe, datenaiss_employe, date_embauche_employe, photo_employe, contrat_employe, fonction_employe, statut_employe, carte_identite_employe, carte_btp_employe ');
    $messages = $stmt->fetchAll(PDO::FETCH_OBJ);
    Vire ces codes. Ensuite utilise une requête préparée.

    A+.

  5. #5
    Membre du Club Avatar de IamKanagawa
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2018
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2018
    Messages : 114
    Points : 54
    Points
    54
    Par défaut
    Citation Envoyé par andry.aime Voir le message
    Ta requête insert est bonne, vire le from de là. Je parle de cette requête qui devait avoir un clause from, et que cette requête ne sert à rien:

    Vire ces codes. Ensuite utilise une requête préparée.

    A+.
    Okay je vais faire cela merci, je vous tiens au courant ^^
    Il faut se tromper dans la vie, pour apprendre et s'améliorer.

    Etudiant BTS-SIO option SLAM

  6. #6
    Membre du Club Avatar de IamKanagawa
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2018
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2018
    Messages : 114
    Points : 54
    Points
    54
    Par défaut
    Bon j'ai essayé de comprendre mais je n'arrive pas trop

    voici le code

    pour se connecter :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    <?php
    try
    {
    	$pdo = new PDO('mysql:host=localhost8889;dbname=bdd', 'root', 'root', array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION ));
    }
    catch(Exception $e)
    {
    	exit('<b>Catched exception at line '. $e->getLine() .' :</b> '. $e->getMessage());
    }
    ?>
    et le code traiment
    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
     
    <?php
    include 'connect_bdd.php';
     
     
    // Préparation des requêtes
    $insert = $db->prepare('INSERT INTO employe_table (matricule_employe, nom_employe, prenom_employe, datenaiss_employe, date_embauche_employe, photo_employe, contrat_employe, fonction_employe, statut_employe, carte_identite_employe, carte_btp_employe) VALUES (?,?,?,?,?,?,?,?,?,?,?)');
    $select = $db->prepare('SELECT matricule_employe, nom_employe, prenom_employe, datenaiss_employe, date_embauche_employe, photo_employe, contrat_employe, fonction_employe, statut_employe, carte_identite_employe, carte_btp_employe FROM employe_table');
    $select->setFetchMode(PDO::FETCH_ASSOC); // Facultatif
     
    // Exécution des requêtes
    $insert->execute(array('root', 'root'));
    $select->execute();
     
    // Récupération des résultats
    $employe_table = $select->fetchAll();
    echo '<pre>';
    print_r($employe_table);
    echo '</pre>';
     
    ?>
    et voici le message d'erreur :
    Catched exception at line 4 : SQLSTATE[HY000] [2002] php_network_getaddresses: getaddrinfo failed: nodename nor servname provided, or not known

    traduction :
    Exception interceptée à la ligne 4: SQLSTATE [HY000] [2002] php_network_getaddresses: getaddrinfo a échoué: nodename ou servname fourni, ou inconnu


    je vois pas où est le probleme à ligne 4
    Il faut se tromper dans la vie, pour apprendre et s'améliorer.

    Etudiant BTS-SIO option SLAM

  7. #7
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    Si je puis me permettre, pour débuter avec pdo et les requêtes préparées, tu as du code prêt à fonctionner ici :

    PDO une soupe et au lit

    Parce que là, tu mélanges un peu tout...
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  8. #8
    Membre du Club Avatar de IamKanagawa
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2018
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2018
    Messages : 114
    Points : 54
    Points
    54
    Par défaut
    Citation Envoyé par Dendrite Voir le message
    Si je puis me permettre, pour débuter avec pdo et les requêtes préparées, tu as du code prêt à fonctionner ici :

    PDO une soupe et au lit

    Parce que là, tu mélanges un peu tout...
    On peut dire ça
    Il faut se tromper dans la vie, pour apprendre et s'améliorer.

    Etudiant BTS-SIO option SLAM

  9. #9
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Citation Envoyé par IamKanagawa Voir le message
    Catched exception at line 4 : SQLSTATE[HY000] [2002] php_network_getaddresses: getaddrinfo failed: nodename nor servname provided, or not known
    L'url que tu as fourni n'est pas bon
    localhost8889
    .

    Ensuite, ce sont les valeurs à inserer que tu dois passer dans l'array dans $insert->execute(array('Les valeurs à inserer'));

    A+.

  10. #10
    Membre du Club Avatar de IamKanagawa
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2018
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2018
    Messages : 114
    Points : 54
    Points
    54
    Par défaut
    Donc j'ai fait ça

    traitement bdd
    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
    <?php
    $db = include 'connect_bdd.php';
     
    //on supprime les guillemets d’une chaîne SQL, PDO s’en occupera
    //on remplace l’id auto-increment par NULL, la table s’en chargera
    $sql='INSERT INTO employe_table (matricule_employe, nom_employe, prenom_employe, datenaiss_employe, date_embauche_employe, photo_employe, contrat_employe, fonction_employe, statut_employe, carte_identite_employe, carte_btp_employe) VALUES (?,?,?,?,?,?,?,?,?,?,?)';
    $db = include 'connect_bdd.php';
    try { 
       //la ligne qui lance la requête préparée
       $stmt = $db->prepare($sql);
       //on affecte les marqueurs précis sur les filtres
       //en vrai, vous aurez plutôt des variables de type POST envoyées par un formulaire
       $matricule_employe='?';
       $nom_employe='?';
       $prenom_employe='?';
       $datenaiss_employe='?';
       $date_embauche_employe='?';
       $photo_employe='?';
       $contrat_employe='?';
       $fonction_employe='?';
       $statut_employe='?';
       $carte_identite_employe='?';
       $carte_btp_employe='?';
     
       //Attention, bien mettre dans l'ordre de la requête ! Nom puis prenom puis mail
       $stmt->execute(array($matricule_employe,$nom_employe,$prenom_employe,$datenaiss_employe,$date_embauche_employe,$photo_employe,$contrat_employe,$fonction_employe,$statut_employe,$carte_identite_employe,$carte_btp_employe));
       // on peut récupérer le nombre de lignes affectées 
       $nb_insert = $stmt->rowCount();
       echo $nb_insert.' insertion effectuée<br/>';
       unset($db);
    } 
    catch (Exception $e) {
       //s'il y a un problème PHP ou SQL, tout s'affichera ici
       print "Erreur ! " . $e->getMessage() . "<br/>";
    }
     
    ?>
    connect code :
    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
    <?php
    // on vérifie si la fonction de connexion a déjà été définie afin d'éviter de la redéfinir
    if ( ! function_exists('connect_bdd')) {
       function connect_bdd() {
          // une fois ouverte, on renvoie toujours la même connexion
          static $pdo;
          // on vérifie si la connexion n'a pas déjà été initialisée
          if ( ! ($pdo instanceof PDO)) {
             // tentative d'ouverture de la connexion MySQL
             try {
                $pdo = new PDO('mysql:host=localhost;port=3306;dbname=bdd;charset=utf8','root', 'root', [
                PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION,
                PDO::ATTR_EMULATE_PREPARES   => false
                ]);
             } 
             catch (PDOException $e) {
                throw new InvalidArgumentException('Erreur connexion à la base de données : '.$e->getMessage());
                exit;
             }
          }
          // renvoi de la ressource : connexion à la base de données
          return $pdo;
       }
    }
    return connect_bdd();
    Mais cela me renvois des valeurs nul ou est mon erreur ?

    PS: Les valeurs à saisir se font par un formulaire avec des input ^^
    Images attachées Images attachées  
    Il faut se tromper dans la vie, pour apprendre et s'améliorer.

    Etudiant BTS-SIO option SLAM

  11. #11
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Pourquoi mettre des ? comme valeur?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $matricule_employe=$_POST['matricule_employe'];
        $nom_employe=$_POST['nom_employe'];
    ...
    A+.

  12. #12
    Membre du Club Avatar de IamKanagawa
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2018
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2018
    Messages : 114
    Points : 54
    Points
    54
    Par défaut
    Citation Envoyé par andry.aime Voir le message
    Pourquoi mettre des ? comme valeur?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $matricule_employe=$_POST['matricule_employe'];
        $nom_employe=$_POST['nom_employe'];
    ...
    A+.
    MERCI pour vos réponses les amis

    Super forum
    Il faut se tromper dans la vie, pour apprendre et s'améliorer.

    Etudiant BTS-SIO option SLAM

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

Discussions similaires

  1. Réponses: 6
    Dernier message: 14/05/2013, 18h57
  2. [MySQL] Problème formulaire PHP/SQL
    Par Maxou73 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 27/01/2011, 20h19
  3. [SQL] php récupération données formulaire + requête sql
    Par cesoir dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 19/04/2007, 16h00
  4. [SQL] formulaire php/sql (liste déroulante) petit soucis
    Par koolgirl dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 13/03/2007, 22h21
  5. Réponses: 11
    Dernier message: 25/07/2006, 22h46

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