Accueil > Forum > > > > Rang d'un enregistrement MySQL
Rang d'un enregistrement MySQL
jeudi 1 mars 2007 à 14:40:13 |
Rang d'un enregistrement MySQL

escorizaweb
|
Bonjour à tous,
Je cherche à connaître le "rang" d'un de mes enregistrements de ma bdd.
Je m'explique, j'ai une table 'joueurs' avec un champ joueur_id, joueur_score.
Je voudrais quand je suis sur la fiche individuelle d'un joueur,
obtenir le rang de ce joueur dans le classement de tous les joueurs de
ma table classés par joueur_score DESC.
En espérant que vous pourrez m'enlever cette épine du pieds car je câle depuis hier,
Merci beaucoup d'avance,
Matthieu 
|
|
jeudi 1 mars 2007 à 16:33:40 |
Re : Rang d'un enregistrement MySQL

syndrael
|
ALors je ferai une requete dans le genre select count(*) as nb from joueurs1, joueurs2 where joueurs1.joueur_score > joueurs2.joueur_score and joueurs2.joueur_id = Ton-id-du-joueur Et tu rajoutes + 1 au résultat. vous en pensez koa tout le monde ?? S.
|
|
jeudi 1 mars 2007 à 18:05:45 |
Re : Rang d'un enregistrement MySQL

mfaraday
|
Salut
Perso je pense pas que escorizaweb crée une table par joueur :)
Moi je ferai plutôt un "select joueur_id from joueurs order by joueur_score desc" après je pense qu'il te faut "passer sous" php et la tu jongles avec le tableau de résultats
$result = mysql_query($sql);
$i = 0;
while($row = mysql_fetch_assoc($result)) { $tab[$i++] = $row['joueur_id']; }
et la tu obtiens un tableau avec $tab[1] : id du joueur
Voili voilou
Flo
|
|
jeudi 1 mars 2007 à 19:18:56 |
Re : Rang d'un enregistrement MySQL

escorizaweb
|
Euhhhh j'ai testé et ça n'a pas l'air de me donner le classement...
|
|
jeudi 1 mars 2007 à 19:19:03 |
Re : Rang d'un enregistrement MySQL

weboide
|
Salut,
à terme, le mieux serait de tenir à jour un champs "position" attribué à chaque utilisateur, que tu mettras à jour à chaque changement de score, t'essaye de garder une table trié comme ca le tri pour changer la position sera linéaire et pas tres complexe (supposons que ce joueur était au milieu avec un score X, et que son score baisse, il faudra parcourir la table vers le bas (donc en moyenne, la moitié mais au pire des cas toute la table..) et décrementer la position à chaque utilisateur parcouru dont le score est supérieur à X et incrémenter celle de l'utilisateur à déplacer.
j'ai peut etre pas été assez clair, mais ca reste basic, c comme si t'insérer une valeur dans un tableau deja trié, tu parcours linéairement et tu le mets à sa bonne place.
Vous en pensez quoi?
|
|
jeudi 1 mars 2007 à 19:33:32 |
Re : Rang d'un enregistrement MySQL

malalam
|
Réponse acceptée !
Hello,
$tab[$row['joueur_id']] = $i++ ;
en fait. Et tu appelles l'index voulu de ton tableau (l'id de ton joueur, en fait) pour connaître son rang. Vaut aussi mieux partir de $i = 1.
Sinon, si tu peux avec ta version de mysql :
SELECT (count( * ) +1) AS rang FROM joueurs WHERE score <= (SELECT joueur_score FROM joueurs WHERE joueur_id =3 ) ORDER BY joueur_score DESC
|
|
jeudi 1 mars 2007 à 19:34:34 |
Re : Rang d'un enregistrement MySQL

malalam
|
Où 3 (joueur_id = 3) est à remplacer par l'id du joueur dont tu visualises la fiche, évidemment...
|
|
vendredi 2 mars 2007 à 00:53:41 |
Re : Rang d'un enregistrement MySQL
|
vendredi 2 mars 2007 à 09:57:25 |
Re : Rang d'un enregistrement MySQL

syndrael
|
Alors là, je m'insurge.. Malalam PLAGISTE euh non.. PLAGIEUR !! LOL !! Ma requete était boooooooonnnnneee !!! Et c'est po elle ki a été acceptéeeeee !! Ouiiiiinnnnnn !!! Par contre, je ne sais pas ce ke ça donne en terme de perfs entre la tienne et la mienne. Je pense ke la tienne mériterait un limit 1 dans le Select imbriqué.. Je demande réparation, NA !!! En tout cas, j'aime voir ses réponses différentes mais ki tiennent la route.. S.
|
|
vendredi 2 mars 2007 à 10:56:36 |
Re : Rang d'un enregistrement MySQL

malalam
|
Heu...la tienne n'était pas bonne, non, vu que tu impliquais 2 tables joueurs, qui n'existent pas ? LIMIT est totalement inutile ici...on fait un COUNT, ça ne renvoie qu'une ligne.
Plus simple, vu que normalement tu as déjà le score du joueur, puisque tu es sur sa fiche :
SELECT (count( * ) +1) AS rang FROM joueurs WHERE score <= {__SCORE_FICHE_JOUEUR__} ORDER BY joueur_score DESC
où {__SCORE_FICHE_JOUEUR__} ets le score de ton joueur :-)
|
|
Cette discussion est classée dans : enregistrement, table, mysql, joueur, rang
Répondre à ce message
Sujets en rapport avec ce message
Problème de boucle [ par SiNeDeNiS ]
Bonjour à tous et chacun !! Voila le bobo .. Je possède une table MySQL avec plusieur enregistrement ..A l'aide d'une boucle "for" je fait afficher le
boucle dans boucle [ par Kevergeek ]
voilà en fait je voudrais faire un systeme de dossier pour afficher des grades des joueurs sur un jeu que chui en train de mettre au point...pour ca j
updater plusieurs lignes en meme temps [ par plasticode ]
here i come again.voilà je mets en place une page modif.php qui fait appel àune base de données mysql avec plusieurs tables liées.Mes mises a jour fon
mp3 MySql [ par RealKEV1 ]
Bonjour,On peut stocker des LONGBLOB dans une table MySql comme des images, mais peut-on aussi le faire avec de petits fichiers mp3???Je pense que cel
Select dans deux table [ par speedylol ]
Bonjour j aimerais selectionner un champs ou plusieur de deux table mes je vois pas comment faire cela sauriez vous m'aider merci? car je débute en ph
besoins d'aide pour E-commerce [ par speedylol ]
Bonjour j aimerais selectionner un champs ou plusieur de deux table mes je vois pas comment faire cela sauriez vous m'aider merci?car je débute en php
Mettre à jour données d'une table [ par yonico ]
Petite question d'un debutant :je voudrais mettre à jour les données d'une table mais je n'y arrive pas voilà ce que j'ai mis :$reponse = mysql_query(
Vider une table mysql de façon automatisé à chaque semaine [ par pyranhaz ]
Bonjour,comment fait-on pour indiquer à une base mysql que l'on désire qu'elle vide le contenu d'une table précise à chaque 7 jours et de façon automa
Doc MySql [ par DuncanIdaho ]
Salutje cherche de la doc sur MySQL : je voudrais savoir comment faire pour, par ex : savoir si une table existe, savoir si un champs existe dans une
dernier enregistrement d'une table mysql [ par arnold002 ]
Bonjour,J'ai une page qui affiche des recettes contenues dans une BDD mysql, sous la forme .../recette.php?id=40 dans l'url.J'affiche sur toutes les p
Livres en rapport
|
Derniers Blogs
GESTION D'EXCEPTION AVEC LES TASKSGESTION D'EXCEPTION AVEC LES TASKS par richardc
Nous avons vu dans un précédent article comment utiliser Task pour effectuer des opérations dans un autre thread.
Malheureusement, comme tout le monde n'est pas parfait, il se peut que cette exécution se passe mal et qu'une exception se produise.
La...
Cliquez pour lire la suite de l'article par richardc DéMARRONS AVEC LES TASKSDéMARRONS AVEC LES TASKS par richardc
Que vous le vouliez ou non, le développement multi-tâche est maintenant une obligation pour toute nouvelle application. Il est donc vital d'en comprendre les mécanismes et de s'y mettre le plus tôt possible.
En attendant le .NET Framework 4.5 avec le...
Cliquez pour lire la suite de l'article par richardc SLIDE & DéMO TECHDAYS 2012 - FAST & FURIOUS XAML APPSSLIDE & DéMO TECHDAYS 2012 - FAST & FURIOUS XAML APPS par Vko
Retrouvez les slides et les démo de ma session Fast & Furious XAML Apps. A ceux qui se posent la question : "est-ce que le code de la DataGrid est disponible?", je vous répondrais "pas encore". Je vais mettre en place un projet codeplex pour part...
Cliquez pour lire la suite de l'article par Vko XNA IS DEAD!XNA IS DEAD! par richardc
Depuis la semaine dernière (et grâce aux TechDays 2012), je me penche activement sur la nouvelle version de Windows, aka Windows 8. Vous me direz, il était temps puisque la première preview date de Septembre dernier.
OK. Remarquez, on n'en est qu'aux...
Cliquez pour lire la suite de l'article par richardc TECHDAYS PARIS 2012 : WINDOWS SERVER "8" QUOI DE 9 !TECHDAYS PARIS 2012 : WINDOWS SERVER "8" QUOI DE 9 ! par ROMELARD Fabrice
Speakers: Fabrice Meillon et Stanislas Quastana Cette session est basée entièrement sur celle donnée lors de la BUILD cet hiver. Il n'y a pas d'ajout d'information en rapport avec cet évènement passé. Windows 8 Server sera intégralem...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Logiciels
DocTranslate (V3.1.0.0)DOCTRANSLATE (V3.1.0.0)DocTranslate est un traducteur de document Microsoft Word, PowerPoint et Excel. Il permet d'autom... Cliquez pour télécharger DocTranslate Tribler (2012)TRIBLER (2012)Tribler est un client pair à pair (P2P/Peer-to-Peer) open source avec la capacité de regarder des... Cliquez pour télécharger Tribler OneSwarm (2012)ONESWARM (2012)Le peer-to-peer qui protège votre vie privée, c'est OneSwarm.
Ce logiciel de peer-to-peer crypté... Cliquez pour télécharger OneSwarm PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V8.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V8.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO Academy System (17.2.1.0)ACADEMY SYSTEM (17.2.1.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System
|