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
TECHDAYS PARIS 2010 : ADMINISTRATION SHAREPOINT 2010TECHDAYS PARIS 2010 : ADMINISTRATION SHAREPOINT 2010 par ROMELARD Fabrice
Animé par: Patrick Guimonet et Benoit Hamet Cette session traitera des différents points exigés durant les taches d'administration : Planification (architecture, hébergement, authentification, .) Opération e...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice [TECHDAYS 2010] #03 - WEB CONTENT MANAGEMENT SOUS SHAREPOINT 2010[TECHDAYS 2010] #03 - WEB CONTENT MANAGEMENT SOUS SHAREPOINT 2010 par pierre
Stephane Cordonnier de MCNext nous présente les fonctionnalités Web Content Management (WCM) sous SharePoint 2010. Qu'est-ce que le WCM ECM, GED, RM, WCM c'est quoi Plateforme SharePoint Versions SharePoint 2010 SharePoint Fondation...
Cliquez pour lire la suite de l'article par pierre [DESIGN PATTERNS] PARTIE 2: DIP: DEPENDENCY INVERSION PRINCIPLE[DESIGN PATTERNS] PARTIE 2: DIP: DEPENDENCY INVERSION PRINCIPLE par tja
C'est le dernier principe des principes du Design Orienté Objet (The Principles of Object Oriented Design) fondés par Robert C. Martin plus connu sous le pseudonyme d'Uncle Bob.
l'image empruntée de LosTechies.
Je ne traite pas les principes dans...
Cliquez pour lire la suite de l'article par tja TECHDAYS PARIS 2010 : SHAREPOINT 2010 POUR LES DéVELOPPEURSTECHDAYS PARIS 2010 : SHAREPOINT 2010 POUR LES DéVELOPPEURS par ROMELARD Fabrice
Animé par: Laurent Cotton Le développement dans SharePoint 2010 passe par plusieurs axes qui seront évoqués dans cette session, mais plus particulièrement les développements simples lié au besoin Business Business Connectivity Services Ce BCS es...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice TECHDAYS PARIS 2010 : PLEINIèRE DERNIER JOURTECHDAYS PARIS 2010 : PLEINIèRE DERNIER JOUR par ROMELARD Fabrice
Cette session est la dernière pleinière de ces 3 jours de TechDays Paris 2010. Généralement, cette troisième journée est plus axée sur l'avenir vu par Microsoft. Après un retour sur l'avenir vu par la Science Fiction ou par ...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Logiciels
DB-MAIN (9.1.0)DB-MAIN (9.1.0)DB-MAIN is a data-modeling and data-architecture tool. It is designed to help developers and anal... Cliquez pour télécharger DB-MAIN Xilisoft DPG Convertisseur (5.1.37.0120)XILISOFT DPG CONVERTISSEUR (5.1.37.0120)Xilisoft DPG Convertisseur offre aux fans de Nintendo DS une bonne solution leur permettant de dé... Cliquez pour télécharger Xilisoft DPG Convertisseur GraphicsGale (2.01.01)GRAPHICSGALE (2.01.01)GraphicsGale est un logiciel de PixelArt avec de nombreuse fonctionnalités permettant de réalisé ... Cliquez pour télécharger GraphicsGale Architecte 3D (Platinum 2010)ARCHITECTE 3D (PLATINUM 2010)Architecte 3D Platinium vous permet de concevoir facilement les plans votre future maison, de l'é... Cliquez pour télécharger Architecte 3D TeamViewer 5 (TeamViewer 5)TEAMVIEWER 5 (TEAMVIEWER 5)Dépanner un ami,expliquer une manipulation devient un jeu d'enfant.
Prise en main d'un autre ord... Cliquez pour télécharger TeamViewer 5
|