Classez un certain champ dans la table de données MySQL
1. Données de la table originale Comme indiqué ci-dessous. . done_seconds est le temps d'achèvement et l'exigence est de classer chaque élément de données en fonction de ce champ.
2. Saisissez l'instruction SQL suivante :
SELECT A.*,@rank:=@rank+1 AS pm FROM (SELECT * FROM task_news_user_done_list ORDER BY done_seconds) A, (SELECT @rank:=0) B
3. Après avoir exécuté cette instruction, le champ pm est ajouté aux résultats de la requête. La valeur de ce champ est le résultat d'un tri basé sur done_seconds. Notez le problème de l’ordre croissant et décroissant.
4. En plus des champs individuels, les valeurs moyennes peuvent également être triées. Si vous souhaitez trier la valeur moyenne de done_seconds pour le même user_email dans le tableau ci-dessus, vous pouvez utiliser l'instruction SQL suivante :
SELECT A.*,@rank:=@rank+1 AS pm FROM (SELECT user_email, AVG(done_seconds) AS done_seconds FROM task_news_user_done_list GROUP BY user_email ORDER BY done_seconds) A, (SELECT @rank:=0) B
5. Les résultats après tri sont les suivants. Le classement à ce moment est le classement moyen de toutes les done_seconds du même user_email.
6. rejoignez-nous selon les besoins, où et d'autres restrictions. Comme indiqué ci-dessous.
Cliquez sur J'aime si vous le trouvez utile.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!