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

Requêtes MySQL Discussion :

Classer selon le resultat d'une expression réguliere ?


Sujet :

Requêtes MySQL

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    434
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 434
    Points : 82
    Points
    82
    Par défaut Classer selon le resultat d'une expression réguliere ?
    Bonjour, voila mon problème, j'utilise un table pour stocker les scores dans mon jeu (Grav-T pour ceux que ça intéressent) dans un VARCHAR, sous la forme [espace]level:score[espace]level:score etc... ce qui peut donner " 1:155 2:342 3:712 ".

    Je voudrais avoir le meilleur (ou les meilleurs) joueurs pour un niveau donné.
    Don à priori il faut faire un SELECT avec un SORT et un expression régulière, mais je ne connais pas trop ça avec mysql. Donc si quelqu'un pouvait m'aider un petit peu.

    Merci

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    434
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 434
    Points : 82
    Points
    82
    Par défaut
    Bon j'ai essayé ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT name 
    FROM gravt.players 
    ORDER BY CAST( SUBSTRING_INDEX( records REGEXP " 1:[0-9]+ " ,":",-1) AS BINARY) DESC
    Mais il doit y avoir un soucis...

  3. #3
    Membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2009
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2009
    Messages : 20
    Points : 47
    Points
    47
    Par défaut
    Salut,

    je pense que tu fais fausse route,
    les regexp de mysql te permettent uniquement de vérifier si une expression se retrouve dans une chaîne, je ne pense pas, ou du moins je n'en ai pas vu la trace dans la doc (mais je peux me montrer), qu'il soit possible d'utiliser des regexp capturantes.

    Là, la regexp ne fait que t'envoyer true (1) ou false (0) suivant la correspondance, ce qui dans ton cas, renverra toujours 1.

    J'imagine que lorsque tu fais:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT SUBSTRING_INDEX( records REGEXP " 1:[0-9]+ " ,":",-1) AS BINARY FROM gravt.players
    c'est bien la seule valeur qu'on te renverra, 1, ce qui forcément ne sert à rien pour le tri.

    Je n'ai pas de solution à te proposer dans l'immédiat (j'aime bien tester avant) mais je crois que la seule possibilité serait de faire un substring du style "va de la position de la première occurrence trouvée "niveau:" + 2 jusqu'au premier espace trouvé depuis cette même position, ce qui devrait pas être compliqué à faire

  4. #4
    Membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2009
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2009
    Messages : 20
    Points : 47
    Points
    47
    Par défaut
    Re,

    voilà:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT name FROM gravt.players ORDER BY CAST(SUBSTRING(records, INSTR(records, '1:')+2, INSTR(SUBSTRING(records, INSTR(records, '1:')+2, length(records)), ' ')-1) AS SIGNED) DESC
    ça fonctionne bien, y a surement moyen de simplifier (là le niveau doit être précisé 2 fois) mais le principal est là.

    A+

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    434
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 434
    Points : 82
    Points
    82
    Par défaut
    Oui en fait j'ai changer de methode pour stocker mes scores, j'ai une table score ou j'enregistre l'id du joueur, le niveau et le score comme ça je classe facilement ce que je veux.
    Merci

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

Discussions similaires

  1. faire une expression réguliere dans rechercher remplacer
    Par fred0655 dans le forum Dreamweaver
    Réponses: 15
    Dernier message: 10/07/2011, 18h49
  2. [RegEx] erreur dans une expression réguliere
    Par vasilov dans le forum Langage
    Réponses: 4
    Dernier message: 24/06/2008, 22h31
  3. [RegEx] Problème avec une expression réguliere
    Par figatelliSTI dans le forum Langage
    Réponses: 4
    Dernier message: 20/02/2008, 09h59
  4. [RegEx] Couper un mot avec une expression réguliere ?
    Par mLk92 dans le forum Langage
    Réponses: 4
    Dernier message: 24/08/2006, 09h34
  5. [RegEx] Difficultés avec une expression réguliere
    Par saint-pere dans le forum Langage
    Réponses: 10
    Dernier message: 24/06/2006, 13h47

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