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 PostgreSQL Discussion :

select contenant une Regex qui ne retourne rien [10]


Sujet :

Requêtes PostgreSQL

  1. #1
    LFC
    LFC est déconnecté
    Membre du Club
    Profil pro
    Inscrit en
    février 2003
    Messages
    96
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : février 2003
    Messages : 96
    Points : 68
    Points
    68
    Par défaut select contenant une Regex qui ne retourne rien
    Bonjour,

    une question simple j'imagine pour vous :

    J'ai une table dont un des champs est de type text.

    Voici une requete réalisée qui confirme que le pattern fonctionne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    'untitre/2' ~* 'untitre/[0-9]' => renvoie true
    Mais dès qu'on est dans la table :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select thefield from latable where thefield ~* 'untitre/2'
    ne renvoie aucun résultat.
    Et pourtant, il y a bien 1 ligne qui contient un champs thefield égal à untitre/[0-9]

    Est-ce que la requete est mal construite ?

    Merci.

  2. #2
    Rédacteur
    Avatar de SQLpro
    Homme Profil pro
    YYYY
    Inscrit en
    mai 2002
    Messages
    19 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : YYYY
    Secteur : Conseil

    Informations forums :
    Inscription : mai 2002
    Messages : 19 389
    Points : 46 046
    Points
    46 046
    Par défaut
    Ceci marchant parfaitement sou PG 12 :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    CREATE TABLE T_MaTable (MaColonne VARCHAR(256));
     
    INSERT INTO T_MaTable VALUES ('untitre/2');
     
    SELECT * FROM T_MaTable where MaColonne ~* 'untitre/2'
    Vous devez avoir d'autres caractères (peut être non imprimables) dans votre chaine de caractères…

    Transtypez là en binaire pour voir…

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Enseignant CNAM PACA - ISEN Toulon - CESI Aix en Provence * * * * *

  3. #3
    LFC
    LFC est déconnecté
    Membre du Club
    Profil pro
    Inscrit en
    février 2003
    Messages
    96
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : février 2003
    Messages : 96
    Points : 68
    Points
    68
    Par défaut
    Bonjour,
    merci pour la réponse, mais le but est que dans la table il y ait une expression regulière.

    Dans l'exemple que vous donnez, est-ce que vous pouvez plutôt insérer :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    CREATE TABLE T_MaTable (MaColonne VARCHAR(256));
     
    INSERT INTO T_MaTable VALUES ('untitre/[0-9]');
     
    SELECT * FROM T_MaTable where MaColonne ~* 'untitre/2'
    et me dire ce que vous avez comme résultat ? Parce que moi cela ne renvoie rien. Et pourtant, untitre/2 devrait être reconnu dans untitre/[0-9] n'est ce pas ?

    J'ajoute aussi que ce site qui teste les regex, lui, donne un résultat :
    https://www.regexplanet.com/share/in...re=yyyyutbm46r

    Merci.

  4. #4
    Modérateur

    Homme Profil pro
    Consultant Teradata
    Inscrit en
    septembre 2008
    Messages
    7 902
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant Teradata

    Informations forums :
    Inscription : septembre 2008
    Messages : 7 902
    Points : 15 793
    Points
    15 793
    Par défaut
    Il suffit d'intervertir votre colonne contenant l'expression régulière et la constante :
    https://www.db-fiddle.com/f/ff8TPtLn81GCvLN8UYzoMA/0

  5. #5
    LFC
    LFC est déconnecté
    Membre du Club
    Profil pro
    Inscrit en
    février 2003
    Messages
    96
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : février 2003
    Messages : 96
    Points : 68
    Points
    68
    Par défaut
    Bonjour,
    nickel, je réalisais la requete à l'envers en fait.
    Effectivement, dans ce sens-là, cela renvoie un résultat.
    Sujet clos.
    Merci bcp

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 15/12/2017, 10h39
  2. une fonction qui ne retourne rien
    Par blackvicking dans le forum AppleScript
    Réponses: 3
    Dernier message: 07/12/2013, 21h54
  3. Requête select into qui ne retourne rien
    Par madevilts dans le forum PL/SQL
    Réponses: 6
    Dernier message: 15/10/2008, 17h25
  4. Select qui ne retourne rien
    Par hunter001 dans le forum SQL
    Réponses: 2
    Dernier message: 12/06/2007, 12h37
  5. SELECT qui ne retourne rien à cause d'anti-slash
    Par mikyfpc dans le forum Outils
    Réponses: 8
    Dernier message: 08/08/2005, 00h04

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