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 :

modification dans la base de données


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations forums :
    Inscription : Octobre 2011
    Messages : 12
    Points : 7
    Points
    7
    Par défaut modification dans la base de données
    Bonjour,
    j'ai un problème dans ma page php, je veux que ma page me permet d'afficher les phases d'une mission et puis les modifier.
    jusqu'à maintenant l'affichage se fait correctement mais la modification non. Par exemple j'ai 2 phases la première est modifiée avec sucées mais le deuxième reste elle même et ne se modifie pas et ça m'affiche le message d'erreur suivant "Duplicate entry for key 'PRIMARY'".
    D’après ce que je sais que ce message est du à la duplication de la clé primaire donc je déduis que lors de la modification, la première phase est replacée par la première ligne et aussi il modifie la deuxième phase avec la première ligne. Je bloque depuis le matin sur ce problème merci de m'aider.
    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
    <?php
    include("connexion.php");
    $req="Select * from phases where nom_miss='$nom_miss'";
    $rs=mysql_query($req);
     
    	echo
    '<form name="form" method="POST">
    			<table class="table table-hover" border=1>
    		<tr>
    			<th> Nom de la phase </th>
    			<th> Date de debut </th>
    			<th> Date de fin </th>
    			<th> Avancement </th>
    		</tr>';
    $i=1;		
    while ($ligne=mysql_fetch_array($rs))
    {
    	$nom_phase=$ligne[0];
    	$date_debut=$ligne[1];
    	$date_fin=$ligne[2];
    	$pourcentage=$ligne[3];
     
    echo $i;
     
    		echo '<tr>
    			<td><input type="text" name="nom_phase'.$i.'" value="'.$nom_phase.'"></td>
    			<td><input type="date" name="date_debut'.$i.'" value="'.$date_debut.'"></td>
    			<td><input type="date" name="date_fin'.$i.'" value="'.$date_fin.'" ></td>
    			<td><input type="text" name="pourcentage'.$i.'" value="'.$pourcentage.'"></td>
    		</tr>';
    $i++;
    $_SESSION['ct']=$i-1;
    }
    echo ('ct :'.$_SESSION['ct']);
    echo ($_POST["nom_phase2"]);
    echo '<div class="col-lg-5">
    				<button type="submit" class="btn btn-primary btn-lg btn-block" name="Modifier" value="Modifier">Valider les modifications</button>
    	</div>';
     
     if(isset($_POST["Modifier"])) 	 
    {
    $ct1=$_SESSION['ct'];
    for($j=1;$j<=$ct1;$j++)	
    { 
    	$nom_phase1=$_POST["nom_phase$j"];
    	$date_debut1=$_POST["date_debut$j"];
    	$date_fin1=$_POST["date_fin$j"];
    	$pourcentage1=$_POST["pourcentage$j"];
     
    	$req1="UPDATE phases SET 
    				nom_phase='$nom_phase1',
    				date_debut='$date_debut1',
    				date_fin='$date_fin1',
    				pourcentage='$pourcentage1'	
    			where nom_miss='$nom_miss'";
    mysql_query($req1) or exit (mysql_error());
    ?>

  2. #2
    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
    Quelle est la clef primaire de ta table ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations forums :
    Inscription : Octobre 2011
    Messages : 12
    Points : 7
    Points
    7
    Par défaut
    Merci @Sabotage pour votre réponse ,
    Ma clé primaire est nom_phase

  4. #4
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut


    Tu ne peux pas faire ça !
    Si tu n'as que deux phases, tu ne pourras jamais respecter la contrainte d'unicité d'une clé primaire si tu as plus de deux enregistrements dans la table !

    Et au passage, oublies définitivement les fonctions mysql_* et passes soit à mysqli_* soit à PDO.
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations forums :
    Inscription : Octobre 2011
    Messages : 12
    Points : 7
    Points
    7
    Par défaut
    @BOVINO c'est sa le problème je sais je veux modifier la 1er phase par les attributs de la 1er phase et la 2em phase par ces attributs aussi et ainsi de suite

  6. #6
    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
    Si la table "phases" contient les phases des missions alors "nom_phase" ne peut pas être une clef primaire : une clef primaire est une reference unique.
    Ajoute une colonne id numérique autoincrementé qui sera ta clef primaire.
    Ensuite tu retires ton mic mac de $_SESSION['ct'] et $id et tu indexes tes champs de formulaire avec l'id de la phase :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <input type="text" name="nom_phase['.$id.']" value="'.$nom_phase.'">
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  7. #7
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations forums :
    Inscription : Octobre 2011
    Messages : 12
    Points : 7
    Points
    7
    Par défaut
    @sabotage merci pour votre réponse sa me parais très logique je test et je vous tiens au courant

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

Discussions similaires

  1. Réponses: 5
    Dernier message: 20/09/2011, 18h55
  2. [Postgres] Aucune modification dans la base de données
    Par Myriouma dans le forum Hibernate
    Réponses: 7
    Dernier message: 30/07/2010, 15h52
  3. Réponses: 1
    Dernier message: 29/04/2009, 17h22
  4. Modification dans la base de données
    Par swilhoss dans le forum Servlets/JSP
    Réponses: 1
    Dernier message: 26/06/2008, 17h44
  5. Réponses: 1
    Dernier message: 29/04/2008, 10h58

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