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 :

Script PHP - INSERT INTO #2 [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre habitué Avatar de Skunka
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2018
    Messages
    135
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 26
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2018
    Messages : 135
    Points : 158
    Points
    158
    Par défaut Script PHP - INSERT INTO #2
    Bonjour, bonsoir!

    Dans la continuité de mon projet de stage, je rencontre un second problème lors d'une insertion: dans un premier temps aucune insertion n'était prise en compte, j'ai donc changer la requête de ma fonction create() par une requête préparée! Malheuresement j'ai toujours un problème avec cette insertion, le dernier champ (dateProchaineRevision) est "null" alors que je le renseigne dans le formulaire.

    Déjà, le 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
     
    <form method="POST" action="Scripts/vehicule_create.php">
    			        		Nom: <input type="text" name="nomVehicule"> <br>
    			        		Immatriculation: <input type="text" name="immatriculation"> <br>
    			        		Catégorie: 	<select name="categorieVehicule" style="width: 230px">
    											<option value="0"> - - - - - - - - </option>
    											<?php
    											$req = "SELECT * FROM categorieVehicule ORDER BY nomCategorieVehicule";
    											try{
    												$stmt = $pdo->prepare($req);
    												$stmt->execute();
    												while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
    													echo "<option value='".$row["numCategorieVehicule"]."'>".$row["nomCategorieVehicule"]."</option>";
    												}
    											}
    											catch(Exception $e){
    												print "Erreur ! ".$e->getMessage(). "<br>";
    											}
    											?>
    										</select> <br>
    			        		Nom abrégé: <input type="text" name="nomVehiculeABRG"> <br>
    			        		Date de la précédente révision: <input type="text" name="dateDerniereRevision"> <br>
    			        		Date de la prochaine révision: <input type="text" name="dateProchaineRevision"> <br>
    			        		<input type="submit" name="Valider">
    			        	</form>
    Ensuite, le formulaire (graphique):

    Nom : Capture.JPG
Affichages : 103
Taille : 36,5 Ko
    On constate que la date de la prochaine révision est bien renseignée.

    Script vehicule_create.php:

    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
     
    <?php 
    include "../include/connexion.php";
    if (isset($_POST['nomVehicule']) && isset($_POST['immatriculation']) && isset($_POST['categorieVehicule']) ) {
     
    	$vide = null;
    	include "../Classe/vehicule.php";
    	$unVehicule = new vehicule ($_POST['immatriculation'], $_POST['nomVehicule'], $_POST['categorieVehicule']);
     
    	$nomABRG = ($_POST['nomVehiculeABRG'] == "") ? $vide : $_POST['nomVehiculeABRG'];
    	$unVehicule->setNomVehiculeABRG($nomABRG);
     
    	$dateDerniere = ($_POST['dateDerniereRevision'] == "") ? $vide : $_POST['dateDerniereRevision'];
    	$unVehicule->setDateDerniereRevision($dateDerniere);
     
    	$dateProchaine = ($_POST['dateProchaineRevision'] == "") ? $vide : $_POST['dateProchaineRevision'];
    	$unVehicule->setDateProchaineRevision($dateProchaine);
     
    	$unVehicule->create();
    	header("Location: ../page_vehicule.php");
    } 
    ?>
    Méthode create() de la classe vehicule:

    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
     
    public function create(){
    		include "../include/connexion.php";
    		try{
    			$req = "INSERT INTO vehicule (numVehicule, immatriculation, numCategorieVehicule, nomVehicule, nomVehiculeABRG, dateDerniereRevision, dateProchaineRevision) VALUES (NULL,?,?,?,?,?,?)";
    			$stmt = $pdo->prepare($req);
    			$params = [$this->_immatriculation, $this->_numCategorieVehicule, $this->_nomVehicule, $this->_nomVehiculeABRG, $this->_dateDerniereRevision, $this->_dateProchaineRevision];
    			echo($req);
    			var_dump($params);
    			$stmt->excute($params); //L'erreur ici est volontaire !! Elle me permet de voir mon "echo" et "var_dump($params)".
    		}
    	    catch(Exception $e){
    	        print "Erreur ! ".$e->getMessage(). "<br/>";
    	    }		
    	}
    Voici ce que j'obtient:

    Nom : Capture.JPG
Affichages : 90
Taille : 43,2 Ko

    Sans mon erreur volontaire, l'insertion s'effectue bien mais laisse la propriété "dateProchaineRevision" vide...
    J'ai relus tous ces codes à plusieurs reprises, par conséquent si quelqu'un me pointe que le problème vient d'une erreur de syntaxe, j'abandonne la progra
    Plus sérieusement, si une personne serait apte à éclairer ma lanterne sur la possible solution à mon problème, je suis preneur!
    Merci d'avance.

    Cordialement,
    Skunka.
    Traverse les rues ...

    Git: https://github.com/BlueSkunka

    Débutant à vie

  2. #2
    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
    Salut. Il nous manque le code de la méthode setDateProchaineRevision
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  3. #3
    Membre habitué Avatar de Skunka
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2018
    Messages
    135
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 26
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2018
    Messages : 135
    Points : 158
    Points
    158
    Par défaut
    Bonjour,
    tu as mis le doigt sur l'erreur, ma méthode ressemblait à ça:

    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    public function setDateProchaineRevision($date){
    	$this->_dateProchaineRevision;
    }

    Autant dire que la source du problème devient évidente...
    Merci, problème rapidement résolu !

    Cordialement,
    Skunka.
    Traverse les rues ...

    Git: https://github.com/BlueSkunka

    Débutant à vie

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

Discussions similaires

  1. [MySQL] Script PHP - INSERT INTO
    Par Skunka dans le forum PHP & Base de données
    Réponses: 20
    Dernier message: 12/06/2018, 15h35
  2. [MySQL] PHP insert into ($variable1)value($variable2)
    Par biobabar dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 18/12/2008, 17h20
  3. Insertion multiples via script php
    Par furtif1 dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 09/04/2007, 17h03
  4. [MySQL] Php et INSERT INTO, avec variables
    Par Djwaves dans le forum PHP & Base de données
    Réponses: 24
    Dernier message: 20/02/2006, 13h53
  5. insert à partir d'un script php
    Par illegalsene dans le forum Oracle
    Réponses: 2
    Dernier message: 05/10/2005, 17h01

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