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

Langage PHP Discussion :

Liste déroulante devant modifier une base de donnée


Sujet :

Langage PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Décembre 2008
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2008
    Messages : 11
    Par défaut [résolu] Liste déroulante devant modifier une base de donnée
    Bonjour,

    Je suis débutante en codage.
    Je travaille sur un site d'annonce ou plus précisément sur le menu d'administration de ce site. Il faut que je puisse poster des annonces depuis l'administration.

    Pour le post de l'annonce tout va bien, tout fonctionne. Maintenant j'ai un soucis pour la modification. Certains des champs sont des menus déroulants ils apparaissent mais me posent deux problèmes.

    - Lors de la modification, j'ai mis un selected pour qu'il m'affiche le champs indiquer lors de l'ajout. Pourtant il continue à me montrait le premier champ existant.

    - La modification ne se fait pas.

    Voici le bout de mon code correspondant aux problèmes :

    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
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
     
     
    if($action=="domodifier"){
    	$modifier=$DB_site->query ("UPDATE annonce SET utilisateurid='$utilisateurid', nom='$nom', race='$race[libelle]', age='$age', villeid='$villeid', sexeid='$sexeid', papiers='$papiers', gains='$gains', aptitudes='$aptitudes', robeid='$robeid', taille='$taille', sire='$sire', prix='$prix', description='$description' WHERE annonceid='$annonceid' ");
    }
     
     
    if($action=="modifier"){
    	$annonce=$DB_site->query_first(" SELECT * FROM annonce WHERE annonceid='$annonceid' ") ;
    	?>
    	Ci-dessous, le menu servant à modifier une annonce déjà existante.
    	<br><br>
    	<FORM action="post_annonce.php" method="get">
    		<input type="hidden" name="action" value="domodifier">
    		<input type="hidden" name="annonceid" value="<?= $annonceid ?>">
    		Utilisateur : <input type="text" name="utilisateurid" value="<?= $annonce[utilisateurid] ?>">
    		<br><br>
    		Nom : <input type="text" name="nom" value="<?= $annonce[nom] ?>">
    		Race :
    		<select name="raceid">
    			<? 
    			$menuraces=$DB_site->query(" SELECT * FROM race ORDER BY libelle") ;
    			while ($menurace=$DB_site->fetch_array()) { 
    				if($menurace=="raceid")
    				{?>
    				<option value="<?= $menurace[raceid] ?>" selected="selected"></option>
    				<? }
    				else { ?>
    				<option value="<?= $menurace[raceid] ?>">
    				<? 
    				echo "$menurace[libelle]"; 
    				?>
    				</option>
    			<? 
    				}
    			} ?>
    		</select>
    		Age : <input type="text" name="age" value="<?= $annonce[age] ?>">
    		Ville : <input type="text" name="villeid" value="<?= $annonce[villeid] ?>">
    		<br><br>
    		Sexe : <input type="text" name="sexeid" value="<?= $annonce[sexeid] ?>">
    		Papiers :
    			<select name="papiers">
    				<option value="1">Oui</option>
    				<option value="0">Non</option>
    			</select>
    		Gains : <input type="text" name="gains" value="<?= $annonce[gains] ?>">
    		Aptitudes : <input type="text" name="aptitudes" value="<?= $annonce[aptitudes] ?>">
    		<br><br>
    		Robes : <input type="text" name="robeid" value="<?= $annonce[robeid] ?>">
    		Taille : <input type="text" name="taille" value="<?= $annonce[taille] ?>">
    		Sire : <input type="text" name="sire" value="<?= $annonce[sire] ?>">
    		Prix : <input type="text" name="prix" value="<?= $annonce[prix] ?>">
    		<br><br>
    		Description : <input type="text" name="description" value="<?= $annonce[description] ?>">
    		<input type="submit" value="Modifier l'annonce">
    	</FORM>
    	<br><br>
    	<br><br>
    	<br><br>
    	<?
    }
    ?>
    Je vous épargne le bout de code menant à la modification, c'est un simple bouton et ça fonctionne ^^
    J'espère que quelqu'un pourra m'aider. Merci.

  2. #2
    Membre éprouvé

    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 448
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 448
    Par défaut
    while ($menurace=$DB_site->fetch_array()) {
    if($menurace=="raceid")
    Comment veux-tu que $menurace qui est un array soit égal à "raceid" qui est une string ?

  3. #3
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Décembre 2008
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2008
    Messages : 11
    Par défaut
    J'en reviens pas d'avoir fait une erreur aussi bête. Comme quoi on relis jamais assez ses codes...
    J'ai essayé de corrigé ça...
    Ça donne donc :

    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
     
    <select name="raceid">
    			<? 
    			$menuraces=$DB_site->query(" SELECT * FROM race ORDER BY libelle") ;
    			while ($menuraces=$DB_site->fetch_array()) { 
    				if($menurace=="raceid")
    				{?>
    				<option value="<?= $menurace[raceid] ?>" selected="selected"></option>
    				<? }
    				else { ?>
    				<option value="<?= $menurace[raceid] ?>">
    				<? 
    				echo "$menuraces[libelle]";
    				?>
    				</option>
    			<? 
    				}
    			} ?>
    		</select>
    Ce qui fonctionnait déjà fonctionne toujours... et ce qui ne fonctionnait pas ne fonctionne toujours pas...

  4. #4
    Membre éprouvé

    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 448
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 448
    Par défaut
    $menurace[raceid]
    Décide toi, array ou string ?

    Par ailleurs si $menurace == "raceid" il le sera à chaque passage dans ta boucle puisque $menurace n'y change pas

  5. #5
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Décembre 2008
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2008
    Messages : 11
    Par défaut
    Je m'excuse j'ai commencé le PHP il y a une semaine (et le codage html il y a 4). Je ne sais pas ce qu'es un string...

    Alors je vais te dire Array, sans en comprendre les conséquences.
    Es-ce gênant si $menurace == "raceid" est toujours dans la boucle ?

  6. #6
    Membre confirmé Avatar de islyoung2
    Homme Profil pro
    Inscrit en
    Juin 2008
    Messages
    236
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42

    Informations forums :
    Inscription : Juin 2008
    Messages : 236
    Par défaut
    Salut; peut tu me donné la structure de tes deux tables (annonce et race).
    je pense que je pourrais t'aider (enfin j'espère )

Discussions similaires

  1. Réponses: 3
    Dernier message: 22/03/2009, 18h47
  2. Réponses: 11
    Dernier message: 09/03/2009, 13h47
  3. Charger une liste déroulante à partir d'une base de donnée
    Par mr_simon dans le forum Balisage (X)HTML et validation W3C
    Réponses: 5
    Dernier message: 04/07/2007, 09h32
  4. [AJAX] lier deux listes déroulantes alimenté par une base de données (Mysql)
    Par arnaudperfect dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 23/04/2007, 02h06
  5. Réponses: 1
    Dernier message: 20/03/2007, 10h24

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