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 :

Afficher 4 éléments de ma bd en aléatoire avec une condition [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    HobbyWeb
    Inscrit en
    Janvier 2005
    Messages
    183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : Suisse

    Informations professionnelles :
    Activité : HobbyWeb

    Informations forums :
    Inscription : Janvier 2005
    Messages : 183
    Par défaut Afficher 4 éléments de ma bd en aléatoire avec une condition
    Bonjour, je souhaite afficher 4 éléments de ma bd au hasard mais avec la condition qu'il s'agisse d'un élément par catégorie (il y a 4 catégories).

    Mon code ci-dessous ou je reste bloqué.. L'affichage aléatoire se fait bien, mais il peut afficher 3 éléments d'une même catégorie et c'est pas le but




    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
    	<?php	mysql_query('SET NAMES utf8');
    		// +------ Requête pour extraire -------+
     
    		/*Récupérer 4 éléments avec 4 catégories différentes ( un seul choix par catégorie => $idc)
    		
    		$idc =1; => apéros
    		$idc =2; => plats
    		$idc =3; => desserts
    		$idc =4; => huiles
    		*/
     
    		// => comment indiquer dans mon query qu'il doit prendre qu'un élément par catégorie ($idc)
     
    		$query = "SELECT * FROM $tablerfx1 WHERE valid='1' order  by RAND() LIMIT 0,4";
    		$succes = mysql_query($query) or die ('requete =>'.$query.'<br> error->'.mysql_error());;
    		$result = mysql_num_rows ($succes);	
     
    		$p=0;
     
    		while ($annuaireData=mysql_fetch_array($succes)) { 	
    		extract($annuaireData);
     
    		$titre = nl2br($titre); 
    		$desch = nl2br($desch);
                    $prix = nl2br($prix);
     
     
    	?>	
     
    			<p>...ma partie html...</p>
     
    				<?php $p++;	}	?>
    D'avance merci pour votre aide
    Yule

  2. #2
    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 : 40
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Le plus simple serait sans doute de faire une requête par catégorie, qui remonte chacune un seul élément.
    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]

  3. #3
    Membre éclairé
    Homme Profil pro
    HobbyWeb
    Inscrit en
    Janvier 2005
    Messages
    183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : Suisse

    Informations professionnelles :
    Activité : HobbyWeb

    Informations forums :
    Inscription : Janvier 2005
    Messages : 183
    Par défaut
    Hello,

    MErci pour cette suggestion, donc j'y vais ainsi

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    <?php
    $query0 = "SELECT * FROM $tablerfx1 WHERE valid='1' and idc='1' order  by RAND() LIMIT 0,1";
    $query1 = "SELECT * FROM $tablerfx1 WHERE valid='1' and idc='2' order  by RAND() LIMIT 0,1";
    $query2 = "SELECT * FROM $tablerfx1 WHERE valid='1' and idc='3' order  by RAND() LIMIT 0,1";
    $query3 = "SELECT * FROM $tablerfx1 WHERE valid='1' and idc='4' order  by RAND() LIMIT 0,1";
     
     
    ?>
    Etc... c'est pas trop lourd tout ça ? ou j'ai pas saisi la finesse dans ta réponse
    A+
    Yule

  4. #4
    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 : 40
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    En utilisant une boucle, ce serait déjà moins lourd au niveau code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $cats = array(1, 2, 3, 4);
    foreach ($cats as $idc) {
    	$query = "SELECT * FROM $tablerfx1 WHERE valid='1' and idc='".$idc."' order  by RAND() LIMIT 0,1";
    	$succes = mysql_query($query) or die ('requete =>'.$query.'<br> error->'.mysql_error());;
    	$result = mysql_num_rows ($succes);	
     
    	$p=0;
     
    	while ($annuaireData=mysql_fetch_array($succes)) { 	
    		extract($annuaireData);
    		// la suite du traitement...
    }
    Et si tu utilisais PDO (ou mysqli, mais j'aime pas mysqli) au lieu de l'API mysql, tu pourrais utiliser les requêtes préparées qui faites exactement pour ce genre de choses : exécuter la même requête plusieurs fois de suite avec des paramètres différents.
    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]

  5. #5
    Membre éclairé
    Homme Profil pro
    HobbyWeb
    Inscrit en
    Janvier 2005
    Messages
    183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : Suisse

    Informations professionnelles :
    Activité : HobbyWeb

    Informations forums :
    Inscription : Janvier 2005
    Messages : 183
    Par défaut
    Re,

    Extra, merci bien pour cette solution
    Bonne journée
    Yule

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

Discussions similaires

  1. [MySQL] afficher des éléments de deux tables en fontion d'une requete
    Par vivi21 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 26/08/2011, 15h55
  2. Réponses: 5
    Dernier message: 31/03/2010, 13h20
  3. Réponses: 1
    Dernier message: 18/10/2007, 00h18
  4. tri aléatoire avec une somme fixe
    Par mikele dans le forum Algorithmes et structures de données
    Réponses: 5
    Dernier message: 23/09/2007, 20h34
  5. Réponses: 4
    Dernier message: 25/01/2007, 14h41

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