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 :

Renumérotation d'une liste dans une BDD à partir de PHP [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Enseignant
    Inscrit en
    Juin 2009
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2009
    Messages : 7
    Points : 5
    Points
    5
    Par défaut Renumérotation d'une liste dans une BDD à partir de PHP
    Bonjour,

    après de nombreuses recherches je n'arrive pas à trouver mon bonheur.

    J'ai créé un site avec une partie administrateur dans laquelle je peux écrire des articles pour qu'ils soient visibles dans la zone publique.

    Je souhaite créer un bouton qui me permet de remonter l'article dans la liste afin de le positionner selon mon souhait.

    Pour cela j'ai créé une colonne affichage dans ma BDD. La valeur 0 correspond à un article non visible, puis ensuite ils sont affichés dans l'ordre de la numérotation.

    Je souhaite :
    - Etre capable de renuméroter cette liste au besoin avec une série de chiffres qui se suivent, un trou peu arriver lorsque je supprime définitivement un article, mais je n'ai rien trouvé qui permet de le faire si ce n'est agir dans mysql directement.
    - Etre capable de faire remonter un article, c'est à dire diminuer son numéro d'affichage pour le substituer à l'article précédent qui prendra la numérotation de l'article déplacé.

    Pour ces deux demandes, je sèche.

    Merci de votre aide

  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
    2 ou 3 exemples valent mieux que de longues explications...
    ET aussi... ton code please...
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  3. #3
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Salut,

    quelque chose dans ce genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $data = range('a', 'z');  // [0 => 'a', 1 => 'b', ..., 25 => 'z']
     
    // supprime la lettre a et réordonne les clés
    unset($data[0]);
    $data = array_values($data);  // maintenant 0 => b
     
    // monter d'un cran la place de la lettre m
    $i = array_search('m', $data, true); // recherche de l'index de la lettre
    if (($i !== false) && ($i > 0))
    {
        list($data[$i], $data[$i - 1]) = [$data[$i - 1], $data[$i]];    // swap des valeurs
    }

  4. #4
    Futur Membre du Club
    Homme Profil pro
    Enseignant
    Inscrit en
    Juin 2009
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2009
    Messages : 7
    Points : 5
    Points
    5
    Par défaut
    @Dendrite

    Désolé, je n'ai pas de code pour cette partie là car je sèche complètement

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Enseignant
    Inscrit en
    Juin 2009
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2009
    Messages : 7
    Points : 5
    Points
    5
    Par défaut
    @rawsrc

    Merci pour cet exemple.

    Si je comprends bien, j'importe ma liste dans un tableau en php, puis je traite en php selon l'exemple donné et enfin je réinvente dans la base à l'issue.

  6. #6
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Pas tout à fait, je t'ai donné la logique que tu dois adapter à la base de données

    Perso, je ne m'occuperais pas des problèmes de trous dans la numérotation, un moteur de base de données s'en tamponne (du moment que ton affichage tient la route)

    Pour le changement d’ordonnancement en base de données, il va te falloir gérer cette problématique soit avec 2 requêtes soit avec une procédure stockée.

  7. #7
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Citation Envoyé par rawsrc Voir le message
    Pour le changement d’ordonnancement en base de données, il va te falloir gérer cette problématique soit avec 2 requêtes soit avec une procédure stockée.
    S'il ne s'agit que deux valeurs:
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    UPDATE table SET colonne = IF(colonne='valeur1','valeur2','valeur1') WHERE colonne IN ('valeur1','valeur2');

    A+.

  8. #8
    Futur Membre du Club
    Homme Profil pro
    Enseignant
    Inscrit en
    Juin 2009
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2009
    Messages : 7
    Points : 5
    Points
    5
    Par défaut
    Bonjour à tous,
    suite à tous vos conseils je pense être arrivé à quelque chose qui tient la route.

    Voici les éléments

    Sur la page où j'ai mes articles :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    <?php
    ...
        if ($result->affichage != recherche_min())
    	{
    	echo('<li><a href=permuter_articles.php?pos_origine='.$result->affichage.'&type_permutation=up&page='.$result->lieu_affichage.'>remonter dans la liste</a></li>');
    	}
        if ($result->affichage != recherche_max())
    	{
    	echo('<li><a href=permuter_articles.php?pos_origine='.$result->affichage.'&type_permutation=down&page='.$result->lieu_affichage.'>baisser dans la liste</a></li>');
    	}
    ...
    ?>
    Les fonctions nécessaires :
    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
     
    <?php
     
        function recherche_max(){
        include('cnx_bdd.php');
     
        $sql_max = "SELECT MAX(affichage) AS affichage_max FROM post_page_accueil WHERE `lieu_affichage`='type' AND affichage!=0";
        $res_max = mysql_query($sql_max) or die('Erreur SQL !<br>'. $sql_max.'<br>'.mysql_error());
        $data_max = mysql_fetch_array($res_max);
     
        return $data_max[0];
    	mysql_close();
        }
     
        function recherche_min(){
        include('cnx_bdd.php');
     
        $sql_min = "SELECT MIN(affichage) AS affichage_min FROM post_page_accueil WHERE `lieu_affichage`='type' AND affichage!=0";
        $res_min = mysql_query($sql_min) or die('Erreur SQL !<br>'. $sql_min.'<br>'.mysql_error());
        $data_min = mysql_fetch_array($res_min);
     
        return $data_min[0];
    	mysql_close();
        }
    ?>
    permuter_articles.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
     
    <?php
     
        // declaration du tableau
        $tab_position = array();
     
        // recuperation des donnees de la page
       $position_origine=$_GET['pos_origine'];
       $type_permutation=$_GET['type_permutation'];
       $location=$_GET['page'];
     
        //connexion serveur et selection base
        include('cnx_bdd.php');
     
        //affectation des valeurs d affichage dans un tableau
        $sql ='SELECT affichage FROM table WHERE lieu_affichage="type" AND affichage!=0 ORDER BY affichage';
        $req = mysql_query( $sql, $cnx ) ;
        $i=1;
        while ($donnee = mysql_fetch_array($req))
    	{
          $tab_position[$i] = $donnee[0];
          $i++;
        }
     
        // recherche de la position d'origine
        $k=1;
        while ($position_origine!=$tab_position[$k])
    	{
    	  $k++;
    	}
     
        // inversion des valeurs dans la BDD
        if($type_permutation=='up') // remonter dans la liste
    	  {
    		$sql_inversion='UPDATE post_page_accueil SET affichage = IF(affichage='.$tab_position[$k-1].','.$tab_position[$k].','.$tab_position[$k-1].') WHERE affichage IN ('.$tab_position[$k-1].','.$tab_position[$k].')';
    		$req_inversion = mysql_query( $sql_inversion, $cnx ) ;	
    	  }
    	  else //descendre dans la liste
    	  {
    		$sql_inversion='UPDATE post_page_accueil SET affichage = IF(affichage='.$tab_position[$k].','.$tab_position[$k+1].','.$tab_position[$k].') WHERE affichage IN ('.$tab_position[$k].','.$tab_position[$k+1].')';
    		$req_inversion = mysql_query( $sql_inversion, $cnx ) ;		
    	  }
    	mysql_close();
    ?>
       // retour sur la page d'origine 
       <script language="JavaScript">
    		 var retour_page = '<?php echo $location ?>';
    		 var adresse_redirection = "window.location='adresse de la page"+retour_page+"'";
    		 setTimeout(adresse_redirection,0); // delai en millisecondes
        </script>
    Je suis dans l'attente de vos remarques éventuelles au niveau sécurité notamment

    Toutefois déjà merci de votre aide

  9. #9
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Remarques en vrac :
    • L'API Mysql est obsolète et supprimée en PHP7. Il va donc falloir remplacer toutes tes fonction mysql_xxx, soit en utilisant mysqli, soit avec PDO. Comprendre PDO
    • Tu n'as pas besoin d'ouvrir et de fermer la connexion à la base à chaque requête. L'ouvrir une fois en début de script et la fermer à la fin est suffisant.
    • Pour faire une redirection immédiate, utilise plutôt header Comment faire une redirection ?
    • Dans tes fonctions, tu as des choses après les return. Or le return fait sortir de la fonction. Donc tout ce qui se trouve après ne sera pas exécuté.
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  10. #10
    Futur Membre du Club
    Homme Profil pro
    Enseignant
    Inscrit en
    Juin 2009
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2009
    Messages : 7
    Points : 5
    Points
    5
    Par défaut
    Bonsoir,
    L'API Mysql est obsolète et supprimée en PHP7...
    -> Je l'admet il va falloir que je me mette à jour sur les procédure

    - Pour faire une redirection immédiate ...
    -> J'ai essayé avec header() mais je galère sur ce sujet malgré les exemples et explication, ça plante

    - Tu n'as pas besoin d'ouvrir et de fermer la connexion à la base à chaque requête. L'ouvrir une fois en début de script et la fermer à la fin est suffisant.
    - Dans tes fonctions, tu as des choses après les return ...
    ->Merci des conseils je vais faire le nécessaire

    J'annonce le sujet résolu, encore merci à tous

  11. #11
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Salut,

    tu peux factoriser :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $html = '<li><a href=permuter_articles.php?pos_origine=%s&type_permutation=%s&page=%d>%s dans la liste</a></li>';
     
    if ($result->affichage != recherche_min())
        printf($html, $result->affichage, 'up', $result->lieu_affichage, 'remonter');
    elseif ($result->affichage != recherche_max())
        printf($html, $result->affichage, 'down', $result->lieu_affichage, 'baisser');

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

Discussions similaires

  1. une liste dans une liste?
    Par JerryOne3 dans le forum C#
    Réponses: 11
    Dernier message: 11/01/2009, 16h43
  2. quand je selectionne une valeur dans une liste, retourne une autre valeur
    Par nsqualli dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 29/12/2008, 14h23
  3. [débutant] Comment gérer une liste dans une liste
    Par Lenoiche dans le forum iReport
    Réponses: 0
    Dernier message: 16/07/2008, 10h41
  4. champ d'une liste lié à une liste dans un autre site
    Par guintolli dans le forum SharePoint
    Réponses: 8
    Dernier message: 08/07/2008, 14h51
  5. Appel d'une liste dans une liste (JSTL)
    Par abalgue dans le forum Hibernate
    Réponses: 4
    Dernier message: 15/06/2007, 10h56

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