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 :

Boucler sur les enregistrements MYSQL


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2010
    Messages
    82
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2010
    Messages : 82
    Par défaut Boucler sur les enregistrements MYSQL
    Bonjour,

    Je cherche depuis plusieurs heures un moyen d'afficher par 3 les enregistrements d'une table.....Mais ça n'est tout

    La difficulté réside dans le fait que ces enregistrements vont être affichés sur un écran d'infos destiné au public. (sans action extérieure)

    La page se recharge toutes les x secondes et doit afficher à chaque fois 3 enregistrements:

    exemple: si ma requete contient 10 enregistrements, je dois avoir cela.

    1,2,3 puis
    4,5,6 puis
    7,8,9 puis
    10,1,2 etc....

    J'essaie de résoudre ce problème avec les variables de session mais je ne sais comment gérer la boucle entre le dernier enregistrement et le premier.

    Si quelqu'un peut me donner un petit coup de pouce, je suis preneur.

    Merci par avance

  2. #2
    Membre émérite Avatar de sebhm
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2004
    Messages
    1 090
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Landes (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2004
    Messages : 1 090
    Par défaut
    Bonjour,

    ca serait bien de voir ce que tu as deja fait
    mais je pense que tu peux t'en sortir en comptant avant ta requete combien il y a d'enregistrements en tout.

    j'imagine que tu as un compteur et que tu fais un truc du genre
    SELECT ... LIMIT <ton_compteur>,3

    Si tu as 10 enregistrements en tout
    lorsque tu arrive à 9 par exemple (donc le dernier puisqu'on commence à zero)
    tu fais toujours
    SELECT ... LIMIT 9,3
    et tu sais qu'il te reste 2 enregistrements à afficher
    (soit tu fais une deuxieme requete dans ce cas, soit tu fais tout dans la meme avec un UNION par exemple)

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2010
    Messages
    82
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2010
    Messages : 82
    Par défaut
    Voici ce que j'ai actuellement.
    Je n'arrive pas à boucler du dernier au 1er enregistrement.
    J'ai actuellement 3 enregistrements valides en base.

    donc il faudrait:
    123,
    231,
    312, etc..


    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
     
    //requete pour selectionner les infos valides avec limite de 3 résultats
    		$sql = "SELECT * FROM ot_lumiweb WHERE station = 'MERIBEL' AND (date_debut <= '".$dateCourante."' AND date_fin >= '".$dateCourante."') LIMIT ".$_SESSION['nbLignes'].",3";
     
     
    $requete = mysql_query($sql, $db) or die( mysql_error() ) ;
     
    //requete pour récup nbre total d'infos valides
    $sql2 = "SELECT * FROM ot_lumiweb WHERE station = 'MERIBEL' AND (date_debut <= '".$dateCourante."' AND date_fin >= '".$dateCourante."')";
     
    $requete2 = mysql_query($sql2, $db) or die( mysql_error() ) ;
     
    $nbre_lignes = mysql_num_rows($requete2);
     
    if ($_SESSION['nbLignes'] < $nbre_lignes)
    {
              $_SESSION['nbLignes'] += 1;
    }
    else $_SESSION['nbLignes'] = 0;

  4. #4
    Expert confirmé

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5 418
    Par défaut
    Comme dit sebhm tu peux jouer sur la clause LIMIT et faire une requête en changeant cette limite à chaque reload de la page.

    Si tu veux ne faire qu'une seule requête initiale tu peux mettre le résultat de ta requête dans un tableau indexé numériquement et enregistré dans une variable de session, et tu incrémente une seconde variable de session qui représente la clé du tableau.

    Par exemple :

    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
    $_SESSION['tab_result'] = isset($_SESSION['tab_result'])? $_SESSION['tab_result'] : array();
    $_SESSION['index'] = isset($_SESSION['index'])? $_SESSION['index'] : 0;
     
    if ($_SESSION['index'] == 0 && count($_SESSION['tab_result']) == 0) 
    {
    //requête
     
    //enregistrement du tableau des résultats dans $_SESSION['tab_result']
     
     
    }
    else if (count($_SESSION['tab_result']) > 0)
    {
    $_SESSION['index']++;
     
    $_SESSION['index'] = $_SESSION['index'] == count($_SESSION['tab_result']) ? 0 : $_SESSION['index'];
    }
     
    //tableau de la ligne à lire
    $ligne = isset($_SESSION['$tab_result'][$_SESSION['index']) ? $_SESSION['$tab_result'][$_SESSION['index'] : '';
    C'est pas testé, juste pour l'idée

  5. #5
    Membre émérite Avatar de sebhm
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2004
    Messages
    1 090
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Landes (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2004
    Messages : 1 090
    Par défaut
    tu as changé de fonctionnement entre tes 2 posts
    c'est 123 345 678 912 346
    ou
    123 234 345 456 567 678 789 891 912
    ??

    quoiqu'il en soit, au moment où tu fais ta premiere requete pour recuperer les 3 lignes
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sql = "SELECT * FROM ot_lumiweb WHERE station = 'MERIBEL' AND (date_debut <= '".$dateCourante."' AND date_fin >= '".$dateCourante."') LIMIT ".$_SESSION['nbLignes'].",3";
    il faut verifier que tu peux en prendre 3 'à la suite', sinon il faut boucler

    donc deja, il te faut le nombre total de ligne avant cette requete

    et ca peut donner un truc du genre
    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
    //requete pour récup nbre total d'infos valides
    $sql = "SELECT * FROM ot_lumiweb WHERE station = 'MERIBEL' AND (date_debut <= '".$dateCourante."' AND date_fin >= '".$dateCourante."')";
    $requete = mysql_query($sql, $db) or die( mysql_error() ) ;
    $nbre_lignes = mysql_num_rows($requete);
     
    //requete pour selectionner les infos valides avec limite de 3 résultats
    $sql .= " LIMIT ".$_SESSION['nbLignes'].",3";
     
    //controle s'il en manque => si oui, on va boucler    
    if ($_SESSION['nbLignes'] > $nbr_lignes-3) 
    {    
        //combien il en manque ?
        $nb_manquants=$nbr_lignes-$_SESSION['nbLignes'];
        //requete pour compléter
        $sql.=" UNION SELECT * FROM ot_lumiweb WHERE station = 'MERIBEL' AND (date_debut <= '".$dateCourante."' AND date_fin >= '".$dateCourante."') LIMIT 0, ".$nb_manquants;
    }
     
    $requete = mysql_query($sql, $db) or die( mysql_error() ) ;
     
    if ($_SESSION['nbLignes'] < $nbre_lignes)
    {
        $_SESSION['nbLignes'] += 1;
    }
    else $_SESSION['nbLignes'] = 0;

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2010
    Messages
    82
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2010
    Messages : 82
    Par défaut
    Non le fontionnement est bien:
    1-2-3 puis 4-5-6 puis 7-1-2 etc...

    J'ai tenté avec ton code mais je ne vois pas où ça cloche.

    J'ai : 1-2-3 puis 4 puis 1-2-3 puis 4 etc...

    Je dois trop avoir le nez dedans. Ca ne me saute pas aux yeux

    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
     
    //requete pour récup nbre total d'infos valides
    $sql = "SELECT * FROM ot_lumiweb WHERE station = 'MERIBEL' AND (date_debut <= '".$dateCourante."' AND date_fin >= '".$dateCourante."')";
    $requete = mysql_query($sql, $db) or die( mysql_error() ) ;
    $nbr_lignes = mysql_num_rows($requete);
     
     
    //requete pour selectionner les infos valides avec limite de 3 résultats
    $sql .= " LIMIT ".$_SESSION['nbLignes'].",3";
     
    //controle s'il en manque => si oui, on va boucler    
    if ($_SESSION['nbLignes'] > $nbr_lignes-3) 
    {    
            //combien il en manque ?
            $nb_manquants = $nbr_lignes-$_SESSION['nbLignes'];
            //requete pour compléter
            $sql.=" UNION SELECT * FROM ot_lumiweb WHERE station = 'MERIBEL' AND (date_debut <= '".$dateCourante."' AND date_fin >= '".$dateCourante."') LIMIT 0, ".$nb_manquants;
    }
     
    $requete = mysql_query($sql, $db) or die( mysql_error() ) ;
     
    if ($_SESSION['nbLignes'] < $nbr_lignes-1)
    {
    	$_SESSION['nbLignes'] += 3;
    }
    else $_SESSION['nbLignes'] = 0;

  7. #7
    Membre émérite Avatar de sebhm
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2004
    Messages
    1 090
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Landes (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2004
    Messages : 1 090
    Par défaut
    affiche les requetes successives qui s'executent

Discussions similaires

  1. [VBA/Excel] Boucler sur les colonnes
    Par jefe.k dans le forum Macros et VBA Excel
    Réponses: 18
    Dernier message: 23/02/2007, 08h42
  2. Boucler sur les numero champs
    Par totoche dans le forum VB 6 et antérieur
    Réponses: 11
    Dernier message: 30/08/2006, 06h29
  3. [VB.NET] Boucler sur les checkbox de mon formulaire
    Par malhivertman1 dans le forum Windows Forms
    Réponses: 2
    Dernier message: 24/08/2006, 10h51
  4. Question sur les index mysql
    Par Cyrius dans le forum Requêtes
    Réponses: 4
    Dernier message: 08/08/2006, 22h25
  5. Réponses: 6
    Dernier message: 20/04/2006, 13h24

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