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

select contenant une Regex qui ne retourne rien [10]


Sujet :

Requêtes PostgreSQL

  1. #1
    LFC
    LFC est déconnecté
    Membre régulier
    Profil pro
    Inscrit en
    Février 2003
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2003
    Messages : 106
    Points : 70
    Points
    70
    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
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 761
    Points : 52 547
    Points
    52 547
    Billets dans le blog
    5
    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...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    LFC
    LFC est déconnecté
    Membre régulier
    Profil pro
    Inscrit en
    Février 2003
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2003
    Messages : 106
    Points : 70
    Points
    70
    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
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    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 régulier
    Profil pro
    Inscrit en
    Février 2003
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2003
    Messages : 106
    Points : 70
    Points
    70
    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, 09h39
  2. une fonction qui ne retourne rien
    Par blackvicking dans le forum AppleScript
    Réponses: 3
    Dernier message: 07/12/2013, 20h54
  3. Requête select into qui ne retourne rien
    Par madevilts dans le forum PL/SQL
    Réponses: 6
    Dernier message: 15/10/2008, 16h25
  4. Select qui ne retourne rien
    Par hunter001 dans le forum SQL
    Réponses: 2
    Dernier message: 12/06/2007, 11h37
  5. SELECT qui ne retourne rien à cause d'anti-slash
    Par mikyfpc dans le forum Outils
    Réponses: 8
    Dernier message: 07/08/2005, 23h04

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