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 :

Fonction UPDATE


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    14
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 14
    Par défaut Fonction UPDATE
    Bonjour à tous,
    J'ai un souci avec un code de modification de news.

    Le premier script affiche la liste des news avec pour chacune un lien "supprimer" et un lien "modifier",qui font tous deux appel au même script mais avec une instruction différente.notons que seule l'instruction "modifier" foire.:

    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
     
    <?
    mysql_connect ("******.fr", "nomdusite", "motdepasse");
    mysql_select_db ("base1");  
    $num = mysql_num_rows(mysql_query("SELECT * FROM actu")); 
     
    if ($num ==0)
    {echo "Il n'y à pas de news!";
    }
    else {
    $reponse = mysql_query ("SELECT * FROM actu ")or die(mysql_error());
    while ($donnees = mysql_fetch_array($reponse))
    {
    echo$donnees['Titre'];
    echo "....";
    echo$donnees['date'];
    ?> <a href='operation.php?id=<?
    echo$donnees['id'];
    ?>&amp;instruction=modifier'><?
    echo "MODIFIER";
    echo "</a>";
    ?>  
    <a href='operation.php?id=<?
    echo$donnees['id'];
    ?>&amp;instruction=supprimer'><?
    echo "SUPPRIMER";
    echo "</a>";
    ?>
     
     <br/> <br/>
     
    <?
     
    }
    mysql_close();
    }
    ?>

    voiçi maintenant le code "opération.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
    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
     
    <? if ($_GET["instruction"]== "modifier")
     {
     mysql_connect ("******fr", "nomdusite", "motdepasse");
    mysql_select_db ("base1");  
    $reponse = mysql_query ("SELECT * FROM actu WHERE id=$_GET[id]");
    $donnees = mysql_fetch_array($reponse);
    mysql_close();
    ?>
     
     
    <body><br />
     
    Créer une nouvelle annonce : 
    <br />
    <br />
     
    <form action="update.php" enctype="multipart/form-data" method="POST">
    Titre  : 
    <input name="titre" type="text" id="titre" value="<?echo$donnees['Titre'];?>" size="45" maxlength="40" 
            Date  : 
           <input name="date" type="text" id="date" value="<?echo$donnees['date'];?>" size="11" maxlength="40" />
     
     
     
            Texte  :
     
     
          <textarea name="newst" id="newst" rows="10" wrap="virtual" cols="40"> <?echo $donnees['Contenu'];?> </textarea>
     
            <input name="fichier1" type="file" value="<?echo$donnees['fichier'];?>"/>
     
    <input name="id" type="hidden" value="<?echo $_GET['id'];?>" />
     
          <input name="submit" type="submit" value="Valider l'annonce" />
     
    </form>
     
     
    </body>
    <?}
    elseif ($_GET["instruction"]=="supprimer")
     {
     mysql_connect ("******fr", "nomdusite", "motdepasse");
    mysql_select_db ("base1");  
     mysql_query ("DELETE FROM actu WHERE id=$_GET[id]");
    mysql_close();
     
    ?>
     
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" lang="fr" xml:lang="fr">
      <head>
    <META HTTP-EQUIV="Refresh" CONTENT="1;URL=liste_news.php">  
    </head>
    <body>
    <p> News supprimée! </p>
    </body>
    </html>
    <?
    } 
    ?>

    maintenant le script "update.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
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
     
    <?php
     
    $date=$_POST['date'];
    $titre=$_POST['titre'];
    $contenu=$_POST['newst'];
    mysql_connect (".....", ".........", "......");
    mysql_select_db ("lasyrah_1");  
    mysql_query("UPDATE actu SET Titre='$titre',Contenu='$contenu',date='$date',WHERE id='$_POST['id']'");
     
    mysql_close();
    if ($_FILES["fichier1"] ["size"] > 0)
    {
    mysql_connect ("......", "....", "...."); // la table noms sert à donner un nom définitif  et unique sous forme de chiffre au fichier 
    mysql_select_db ("lasyrah_1"); 
    mysql_query("INSERT INTO noms VALUES('')");
    $num1 = mysql_num_rows(mysql_query ("SELECT * FROM noms"));
    mysql_close();
    $frmat1=explode ( '/' ,$_FILES["fichier1"]["type"]);
    move_uploaded_file($_FILES["fichier1"] ["tmp_name"], "/home/www/lasyrah/www/test/newsimg/". $num1  .".". $frmat1[1]);
    $a = "http://www.la-syrah.fr/test/newsimg/" ;
    $ab="/home/www/lasyrah/www/test/newsimg/";
    $b = ".";
    $c=explode ( '/' ,$_FILES["fichier1"]["type"]);
    $fichier1b=$ab.$num1.$b.$c[1];
    $fichier1=$a.$num1.$b.$c[1];//cette variable contiendra l'adresse du fichier,réutilisée hors de la boucle, à la fin.
    chmod( $fichier1b, 0644);
    }
    if (isset($fichier1))
    {
    mysql_connect ("...", "...", "....");
    mysql_select_db ("..."); 
    mysql_query ("UPDATE actu SET fichier1='$fichier1' WHERE id='$_POST['id']' ");
     
    mysql_close();
     
    }
    ?>
    voilà!
    j'espère avoir posté les bons éléments.
    aussi je vous remercie d'avance!
    Bon week end à vous.
    merci aussi à ceux qui ne peuvent pas répondre,qui échapperont quand même à l' envellope d'entrax.
    :p

  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
    Par défaut
    Bonjour,

    Peux-tu nous dire precisemment ce que tu obtiens comme mauvais resultat ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    14
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 14
    Par défaut
    eh bien les nouvelles informations ne s'insrivent pas dans la base de données,les anciennes restent et après le script j'arrive donc sur une page blanche . peut être devrais je utiliser un mysql error pour connaitre le problème.

    EDIT: rien ne s'affiche avec mysql error....

    celà peut il venir d'un script java que j'utilise avec le formulaire qui apparait pour modifier la news?

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    131
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 131
    Par défaut
    Citation Envoyé par nekashokoi Voir le message
    voiçi maintenant le code "opération.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
    23
    24
     
    <? if ($_GET["instruction"]== "modifier")
     {
     mysql_connect ("******fr", "nomdusite", "motdepasse");
    mysql_select_db ("base1");  
    $reponse = mysql_query ("SELECT * FROM actu WHERE id=$_GET[id]");    
     
    ICI remplace where id=$_GET[id] par id=$_GET['id']
     
    $donnees = mysql_fetch_array($reponse);
    mysql_close();
    ?>
     
    ICI pareil
     
    <input name="id" type="hidden" value="<?echo $_GET['id'];?>" />
     
          <input name="submit" type="submit" value="Valider l'annonce" />
     
     
     mysql_query ("DELETE FROM actu WHERE id=$_GET['id']");
    mysql_close();
     
    ?>
    Test ça ?

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    14
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 14
    Par défaut
    ça n'a rien changé.

Discussions similaires

  1. erreur dans la fonction update (en asp)
    Par leclone dans le forum ASP
    Réponses: 1
    Dernier message: 26/05/2006, 10h00
  2. Fonction UPDATE dans un ADOQuery - SQL
    Par yanba dans le forum Bases de données
    Réponses: 1
    Dernier message: 18/03/2006, 13h53
  3. Problème fonction UPDATE
    Par Mael Bo dans le forum Langage SQL
    Réponses: 3
    Dernier message: 08/02/2006, 15h54
  4. astuce avec fonction update
    Par cubepiege dans le forum Langage SQL
    Réponses: 2
    Dernier message: 08/11/2005, 10h54
  5. [Update TQuery]Lenteur de la fonction Update
    Par Eric SAULNIER dans le forum Bases de données
    Réponses: 2
    Dernier message: 11/05/2004, 01h29

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