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 :

REGEXP - expression correcte, résultat incorrect [MySQL-5.5]


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Intégrateur d'exploitation
    Inscrit en
    Avril 2014
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Intégrateur d'exploitation
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2014
    Messages : 17
    Par défaut REGEXP - expression correcte, résultat incorrect
    Bonjour,

    Je fais suite à mon précédent topic : https://www.developpez.net/forums/d1...onquent-texte/

    J'aimerais rendre ceci un peu plus sexy le REPLACE maintenant car j'ai des champs un peu foireux :/

    Cette regex fonctionne :
    et me permet de filtrer ce genre de contenu :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    [youtube]ZFgYfesx47[/youtube]
    [youtube:az356Gssdfser]ZFgYfesx47[/youtube]
    [youtube:az356Gssdfser]ZFgYfesx47[/youtube:az356Gssdfser]
    J'ai volontairement omis la seconde moitiée (le /youtube) pour le moment.

    Mais à l'exécution dans phpMyAdmin, ça me renvoie tout le contenu de la table ...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT post_text FROM `phpbb_posts2` WHERE post_text REGEXP '\[youtube\:*(\d*\w*)\]'

    Qu'est-ce qui cloche dans ma requête ?

    Merci

  2. #2
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    bonjour


    essayez en doublant les antislashes.

  3. #3
    Membre averti
    Homme Profil pro
    Intégrateur d'exploitation
    Inscrit en
    Avril 2014
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Intégrateur d'exploitation
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2014
    Messages : 17
    Par défaut
    Bonjour

    Ceci semble fonctionne, je dois regarder ça plus en détail mais il semble que c'est bon

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT post_text FROM `phpbb_posts2` WHERE post_text REGEXP 'youtube:?\\w*'
    Edit :
    Ca avance, j'arrive à échapper le crochet du début, mais pas celui de la fin ...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT post_text FROM `phpbb_posts2` WHERE post_text REGEXP '\\[youtube:?\\w*' AND post_text REGEXP '\\[/youtube:?\\w*'
    Dès que je rajoute "\\]", la requête ne renvoie aucune ligne.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT post_text FROM `phpbb_posts2` WHERE post_text REGEXP '\\[youtube:?\\w*\\]' AND post_text REGEXP '\\[/youtube:?\\w*\\]'
    Edit2 :
    Je tiens le bon bout !
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT post_text FROM `phpbb_posts2` WHERE post_text REGEXP '[[.\[.]]youtube:?[[:alnum:]]*[[.\].]]'

  4. #4
    Membre averti
    Homme Profil pro
    Intégrateur d'exploitation
    Inscrit en
    Avril 2014
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Intégrateur d'exploitation
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2014
    Messages : 17
    Par défaut
    Maintenant que j'y pense ... Vu qu'on ne peut pas faire de REGEXP dans un REPLACE ... Ca a presque servi à rien mon truc, hormis me dérouiller en regex

  5. #5
    Membre prolifique Avatar de Artemus24
    Homme Profil pro
    Agent secret au service du président Ulysses S. Grant !
    Inscrit en
    Février 2011
    Messages
    6 917
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Agent secret au service du président Ulysses S. Grant !
    Secteur : Finance

    Informations forums :
    Inscription : Février 2011
    Messages : 6 917
    Par défaut
    Salut Chour.

    Citation Envoyé par Chour
    Qu'est-ce qui cloche dans ma requête ?
    Vous n'utilisez pas la bonne syntaxe pour les expression régulière. Vous êtes sous MySql et non sous php !
    --> https://dev.mysql.com/doc/refman/5.7/en/regexp.html

    Voici un exemple de sélection :
    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
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    --------------
    SET AUTOCOMMIT = 0
    --------------
     
    --------------
    START TRANSACTION
    --------------
     
    --------------
    DROP DATABASE IF EXISTS `base`
    --------------
     
    --------------
    CREATE DATABASE `base`
        DEFAULT CHARACTER SET `latin1`
        DEFAULT COLLATE       `latin1_general_ci`
    --------------
     
    --------------
    DROP TABLE IF EXISTS `test`
    --------------
     
    --------------
    CREATE TABLE `test`
    ( `id`    integer unsigned not null auto_increment primary key,
      `lib`   varchar(255)     not null
    ) ENGINE=InnoDB
      DEFAULT CHARSET=`latin1` COLLATE=`latin1_general_ci`
      ROW_FORMAT=COMPRESSED
    --------------
     
    --------------
    insert into `test` (`lib`) values
      ('[youtube]ZFgYfesx47[/youtube]'),
      ('[youtube:az356Gssdfser]ZFgYfesx47[/youtube]'),
      ('[youtube:az356Gssdfser]ZFgYfesx47[/youtube:az356Gssdfser]')
    --------------
     
    --------------
    select * from `test`
    --------------
     
    +----+-----------------------------------------------------------+
    | id | lib                                                       |
    +----+-----------------------------------------------------------+
    |  1 | [youtube]ZFgYfesx47[/youtube]                             |
    |  2 | [youtube:az356Gssdfser]ZFgYfesx47[/youtube]               |
    |  3 | [youtube:az356Gssdfser]ZFgYfesx47[/youtube:az356Gssdfser] |
    +----+-----------------------------------------------------------+
    --------------
    select    lib
        from  test
       where  lib regexp '[[.left-square-bracket.]]youtube[[.right-square-bracket.]][[:alnum:]]*[[.left-square-bracket.]]/youtube[[.right-square-bracket.]]'
    --------------
     
    +-------------------------------+
    | lib                           |
    +-------------------------------+
    | [youtube]ZFgYfesx47[/youtube] |
    +-------------------------------+
    --------------
    select    lib
        from  test
       where  lib regexp '[[.left-square-bracket.]]youtube:[[:alnum:]]*[[.right-square-bracket.]][[:alnum:]]*[[.left-square-bracket.]]/youtube[[.right-square-bracket.]]'
    --------------
     
    +---------------------------------------------+
    | lib                                         |
    +---------------------------------------------+
    | [youtube:az356Gssdfser]ZFgYfesx47[/youtube] |
    +---------------------------------------------+
    --------------
    select    lib
        from  test
       where  lib regexp '[[.left-square-bracket.]]youtube:[[:alnum:]]*[[.right-square-bracket.]][[:alnum:]]*[[.left-square-bracket.]]/youtube:[[:alnum:]]*[[.right-square-bracket.]]'
    --------------
     
    +-----------------------------------------------------------+
    | lib                                                       |
    +-----------------------------------------------------------+
    | [youtube:az356Gssdfser]ZFgYfesx47[/youtube:az356Gssdfser] |
    +-----------------------------------------------------------+
    --------------
    COMMIT
    --------------
     
    --------------
    SET AUTOCOMMIT = 1
    --------------
     
    Appuyez sur une touche pour continuer...
    @+

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

Discussions similaires

  1. [RegExp]Expressions régulières
    Par Guybrush dans le forum Collection et Stream
    Réponses: 6
    Dernier message: 03/04/2006, 10h13
  2. [Regexp] expressions regulieres et commentaires
    Par floanne dans le forum Langage
    Réponses: 12
    Dernier message: 09/02/2006, 11h52
  3. Réponses: 7
    Dernier message: 27/07/2005, 12h41
  4. [RegExp]expression régulière
    Par illegalsene dans le forum Langage
    Réponses: 2
    Dernier message: 16/04/2005, 15h33
  5. Expression filtre terminé incorrectement.
    Par cre3000 dans le forum Bases de données
    Réponses: 1
    Dernier message: 05/04/2005, 19h59

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