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

 Oracle Discussion :

Select avec un like'%'


Sujet :

Oracle

  1. #1
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    380
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 380
    Points : 480
    Points
    480
    Par défaut Select avec un like'%'
    Bonjour,

    Dans une application, j'effectue la construction d'une requête, le construction est assez complexe. Du coup, pour me simplifier la vie dans certains cas je peux utiliser des clauses like 'vide', c'est à dire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT .... FROM .... WHERE .... AND mon_champ LIKE '%'
    Dans la pratique, je veux retrouver l'ensemble des valeurs (sauf null).

    Je voudrais savoir en terme de performance, si je peux laisser la recherche comme cela, ou s'il vaut mieux que je supprime la clause quand la valeur est vide.

    Merci d'avance.

  2. #2
    Expert éminent
    Avatar de pachot
    Homme Profil pro
    Developer Advocate YugabyteDB
    Inscrit en
    Novembre 2007
    Messages
    1 821
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Suisse

    Informations professionnelles :
    Activité : Developer Advocate YugabyteDB
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2007
    Messages : 1 821
    Points : 6 443
    Points
    6 443
    Billets dans le blog
    1
    Par défaut
    Bonjour,

    Oracle n'a pas l'air d'enlever:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    SQL> set autotrace on explain
    SQL> select * from dual where dummy like '%';
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    --------------------------------------------------------------------------
    | Id  | Operation	  | Name | Rows  | Bytes | Cost (%CPU)| Time	 |
    --------------------------------------------------------------------------
    |   0 | SELECT STATEMENT  |	 |     1 |     2 |     3   (0)| 00:00:01 |
    |*  1 |  TABLE ACCESS FULL| DUAL |     1 |     2 |     3   (0)| 00:00:01 |
    --------------------------------------------------------------------------
     
    Predicate Information (identified by operation id):
    ---------------------------------------------------
     
       1 - filter("DUMMY" LIKE '%' AND "DUMMY" IS NOT NULL)
    Mais je ne pense pas que ca prenne beaucoup de cpu non plus.

    Cordialement,
    Franck.
    Franck Pachot - Developer Advocate Yugabyte 🚀 Base de Données distribuée, open source, compatible PostgreSQL
    🗣 twitter: @FranckPachot - 📝 blog: blog.pachot.net - 🎧 podcast en français : https://anchor.fm/franckpachot

  3. #3
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 073
    Points
    19 073
    Par défaut
    Citation Envoyé par eric39 Voir le message
    Dans la pratique, je veux retrouver l'ensemble des valeurs (sauf null).
    Et pourquoi pas mon_champ IS NOT NULL alors ?

  4. #4
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    380
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 380
    Points : 480
    Points
    480
    Par défaut
    Bonjour,

    Tout d'abord, merci pour vos réponses.

    Et pourquoi pas mon_champ IS NOT NULL alors ?
    En fait, la construction de la requête est assez complexe, dans certains cas, la valeur peut être renseignée dans d'autres non. Je voulais éviter, si ça n'est pas génant au niveau performance, de rajouter un cas spécifique quand la valeur a tester n'est pas renseignée.

    Dans certains cas j'ai une valeur:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT .... FROM .... WHERE .... AND mon_champ LIKE 'Abcd%'
    Dans d'autres non:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT .... FROM .... WHERE .... AND mon_champ LIKE '%'
    Si je laisse le like '%', la construction de la requête est la même dans les deux cas, sinon il faut que je fasse un traitement particulier lorsque la valeur a tester est vide.

    Merci.

  5. #5
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 073
    Points
    19 073
    Par défaut
    j'ajouterais quand même la clause NOT NULL tout le temps

  6. #6
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    380
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 380
    Points : 480
    Points
    480
    Par défaut
    Pardon, j'avais compris qu'il fallait remplacer le like '%' par not null.

    Je n'avais pas compris qu'il était préférable de l'ajouter tout le temps, désolé

    Merci.

  7. #7
    Expert éminent
    Avatar de pachot
    Homme Profil pro
    Developer Advocate YugabyteDB
    Inscrit en
    Novembre 2007
    Messages
    1 821
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Suisse

    Informations professionnelles :
    Activité : Developer Advocate YugabyteDB
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2007
    Messages : 1 821
    Points : 6 443
    Points
    6 443
    Billets dans le blog
    1
    Par défaut
    Alors ceci sera plus optimisé et pas beaucoup plus complexe à générer:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE ( 'Abcd'<>'%' or mon_champ LIKE 'Abcd%')
    et donc si au lieu d'Abcd tu as une chaine vide, cela donnera:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE mon_champ is not null and ( '%'<>'%' or mon_champ LIKE 'Abcd%')
    et l'optimiseur va voir que l'expression entre parenthèse est toujours vraie, et ne pas l'évaluer.
    Franck Pachot - Developer Advocate Yugabyte 🚀 Base de Données distribuée, open source, compatible PostgreSQL
    🗣 twitter: @FranckPachot - 📝 blog: blog.pachot.net - 🎧 podcast en français : https://anchor.fm/franckpachot

  8. #8
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 073
    Points
    19 073
    Par défaut
    Citation Envoyé par eric39 Voir le message
    Pardon, j'avais compris qu'il fallait remplacer le like '%' par not null.
    C'est bien ce à quoi je pensais

  9. #9
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    380
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 380
    Points : 480
    Points
    480
    Par défaut
    Merci beaucoup.

    Je vais tenter d'appliquer vos conseils,

    merci encore.

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

Discussions similaires

  1. Problème de Select avec LIKE
    Par DeWaRs dans le forum Langage SQL
    Réponses: 15
    Dernier message: 10/05/2012, 09h58
  2. Requete SELECT avec LIKE et =
    Par yasoft dans le forum Requêtes
    Réponses: 10
    Dernier message: 07/09/2009, 00h46
  3. Réponses: 3
    Dernier message: 09/06/2008, 09h17
  4. [MySQL] Requête SELECT avec LIKE : pb de CASSE
    Par pcayrol dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 05/06/2007, 20h11
  5. [VB.NET]Requete SELECT avec un Like
    Par krfa1 dans le forum Windows Forms
    Réponses: 5
    Dernier message: 09/01/2007, 17h24

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