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 :

Pas de transmission $_POST à partir d'un menu déroulant [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2012
    Messages
    37
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aube (Champagne Ardenne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2012
    Messages : 37
    Par défaut Pas de transmission $_POST à partir d'un menu déroulant
    Bonjour à tous,

    Après quelques soucis divers, j'ai réussi à afficher dans un menu déroulant, les entrées pour des jours fériés, le nom (en varchar) et la date (en date).
    Toutefois, quand je souhaite modifier ou supprimer en appelant un fichier, rien ne se passe aussi bien au niveau de la suppression que de la modification.

    Je sais que pour le menu déroulant j'utilise mysql_fetch_row qui n'est pas vraiment conseillé par php.net mais je le fait en attendant de passer à pdo(en fait quand tout sera opérationnel).

    Donc, je ne vois pas trop où j'ai commis l'impair, j'accepte toutes les lumières pour éclairer à la découverte d'une solution

    Voici le fichier html

    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
     
    <form method="POST" action="valid_sup_ferie.php">
    <select name="supferie" class="acces">
    	<?
    		mysql_connect("localhost",USER,PASS);
    		mysql_select_db(BASE);
    		$req="SELECT nomferie, dateferie FROM ferie ORDER BY nomferie";
    		$id=mysql_query($req);
    		$i=0;
    		while($resultat=mysql_fetch_row($id))
    		{
    			$jour=$resultat[0];
    			$date=$resultat[1];
    			echo '<option value="'.$jour.'">'.$jour.' - '.$date'</option>';
    			$i++;
    		}
    	?>
    </select>
    <input type="submit" value="Supprimer" class="acces"/>
    </form>
    et le traitement.php

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    <?
    	$cx=mysql_connect("localhost",USER,PASS);
    	$test=mysql_select_db(BASE);
    	$supferie=mysql_real_escape_string($_POST['supferie']);
    	$req="DELETE FROM ferie WHERE id_ferie='$supferie'";
    	$result=mysql_query($req);
    ?>

  2. #2
    Membre éprouvé Avatar de redoran
    Homme Profil pro
    Développeur-Amateur
    Inscrit en
    Juin 2010
    Messages
    1 346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur-Amateur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 346
    Par défaut
    de préférence utilise PDO.
    sépare la connexion dans un fichier a part.
    il te manque le name de l'input:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <input type="submit" name="suppr" value="Supprimer" class="acces"/>
    quel est le résultat du var_dump de la variable $_POST['supferie']?
    ensuite faut:
    testé si le formulaire est validé
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    <?php
    .....
    if (isset($_POST['suppr']) AND isset($_POST[' supferie'])) 
     {
     ton code
     }
    else
    {
    autre alternative
    }
    ?>

  3. #3
    Membre Expert Avatar de Fench
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Mai 2002
    Messages
    2 353
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Groenland

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 353
    Par défaut
    Bonjour,

    en plus de Redoran:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $req="DELETE FROM ferie WHERE id_ferie='$supferie'";
    en
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $req="DELETE FROM ferie WHERE id_ferie=$supferie";

  4. #4
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2012
    Messages
    37
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aube (Champagne Ardenne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2012
    Messages : 37
    Par défaut
    Bonjour redoran et merci d'avance pour les coups de pouces que tu peux me donner donc j'ai fait les manipulations que tu m'as fournies

    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
    <form method="POST" action="valid_sup_ferie.php">
    <select name="supferie" class="acces">
    	<?
    		mysql_connect("localhost",USER,PASS);
    		mysql_select_db(BASE);
    		$req="SELECT nomferie, dateferie FROM ferie ORDER BY nomferie";
    		$id=mysql_query($req);
    		$i=0;
    		while($resultat=mysql_fetch_row($id))
    		{
    			$jour=$resultat[0];
    			$date=$resultat[1];
    			echo '<option value="'.$jour.'">'.$jour.' - '.$date'</option>';
    			$i++;
    		}
    	?>
    </select>
    <input type="submit" name="suppr" value="Supprimer" class="acces"/>
    </form>
    ensuite dans le formulaire de traitement j'ai fait ceci j'ai également rajouté un echo supplémentaire (je viens d'y penser grâce à toi ^^) ce qui donne ceci

    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(isset($_POST['suppr']) AND isset($_POST['supferie']))
            {
    	$cx=mysql_connect("localhost",USER,PASS);
    	$test=mysql_select_db(BASE);
    	$supferie=mysql_real_escape_string($_POST['supferie']);
    	$req="DELETE FROM ferie WHERE id_ferie=$supferie";
    	$result=mysql_query($req);
     
            echo $req;
     
            } else {
     
                     echo "Aucune donnée ne peut être effacée !!!";
            }
    ?>

    et du coup à l'affichage par rapport à l'echo $req; j'ai un

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DELETE FROM ferie WHERE id_ferie=Noël
    mais à brûle pour point je ne sais trop comment récupérer l'id qui permettrait de faire la suppression (ou même après une modification de ce type)

  5. #5
    Membre Expert Avatar de Fench
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Mai 2002
    Messages
    2 353
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Groenland

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 353
    Par défaut
    Il faut que tu géres en fonction de l'id et non le nom cad
    requête:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $req="SELECT id_ferie, nomferie, dateferie FROM ferie ORDER BY nomferie";
    puis le select avec des options comme:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    echo '<option value="'.$resultat[0].'">'.$resultat[1].' - '.$resultat[2].'</option>';
    d'ailleur cette ligne manquait la dernière concaténation

    Et enfin le DELETE là c ok

  6. #6
    Membre éprouvé Avatar de redoran
    Homme Profil pro
    Développeur-Amateur
    Inscrit en
    Juin 2010
    Messages
    1 346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur-Amateur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 346
    Par défaut
    donc sa marche est le jour feries c'est noël.
    maintenant on est devant un autre problème de récupération de l'ID

  7. #7
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2012
    Messages
    37
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aube (Champagne Ardenne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2012
    Messages : 37
    Par défaut
    Oui Redoran, c'est ça, c'est Noël (en même temps vu le temps pourri qu'on a eu ses derniers jours, on aurait presque pu y croire tiens )

    Grand merci Fench, effectivement avec le traitement que tu as donné, la suppression est passé nickel, une vraie petite lettre à la poste,

    De ce fait, je vais essayer de m'en inspirer pour la modification car la base est identique (toujours à partir d'un menu déroulant) mais le traitement est un peu plus particulier

    Voici ma base à partir duquel je vais essayer d'adapter ta solution

    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
    <?
    	$cx=mysql_connect("localhost",USER,PASS);
    	$test=mysql_select_db(BASE);
    	$fer=mysql_real_escape_string($_POST['fer']);
    	$req="SELECT * FROM ferie WHERE id_ferie=$fer";
    	$result=mysql_query($req);
    	$data=mysql_fetch_object($result);
    ?>
    <form method="POST" action="valid_modif_ferie.php">
    	<input type="hidden" name="hiddenfer" value="<? echo $data->id_ferie; ?>" />
    	<p>Nom actuel du jour férié : <input type="text" name="actuelfer" value="<? echo $data->nomferie; ?>" class="input"/></p>
    	<p>Nouveau nom du jour férié : <input type="text" name="modiffer" value=" " class="input"/></p>
    	<p>Date actuelle du jour férié : <input type="text" name="actueldate" value="<? echo $data->dateferie; ?>" class="input"/></p>
    	<p>Nouvelle date du jour férié : <input type="text" name="modifdate" value=" " id="date" class="input"/></p>
    	<input type="submit" value="Valider la modification" class="acces"/>
    </form>
    Je viens d'essayer et ça marche nickel, un grand merci à vous deux, sujet résolu

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

Discussions similaires

  1. griser des menus déroulants à partir d'un menu déroulant
    Par lumycaan dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 15/01/2010, 01h02
  2. Valeur NULL affectée à une BD à partir d'un menu déroulant
    Par martinn dans le forum Ruby on Rails
    Réponses: 3
    Dernier message: 09/05/2009, 21h11
  3. Selection a partir d'un menu déroulant vers un champs
    Par pony99 dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 01/12/2008, 17h36
  4. Réponses: 1
    Dernier message: 01/11/2005, 03h24
  5. [mise à jour d'une iframe à partir d'un menu déroulant]
    Par Lady_jade dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 21/10/2005, 11h50

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