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

Administration Oracle Discussion :

index sur un substr


Sujet :

Administration Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 206
    Par défaut index sur un substr
    Bonsoir,

    Je n'arrete pas de vous poser des questions, mais j'inspère qu'un jour je pourrais moi aussi aider quelqu'un.

    Pour le moment, je voulais savoir s'il était possible de creer un index sur les 2 premiers chiffres d'une colonne contenant 15 chiffres.

    Si oui, comment faire.

    Pour illustrer mon probleme voici la requete que je voudrais optimiser :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT CODE  table1 , table2 WHERE  SUBSTR(table1,1,2) = table2.code
    Merci

  2. #2
    McM
    McM est déconnecté
    Expert confirmé

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Billets dans le blog
    4
    Par défaut
    Il est où le FROM ?

    Sinon, 2 possibilités :
    1/ Créer un index de fonction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CREATE INDEX XXXX ON TABLE1 (SUBSTR(code, 1,2))
    2/ Créer une colonne VARCHAR2(2) mise à jour par trigger insert/update qui fait un substr(:new.code,1,2)

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 206
    Par défaut
    MCM, merci pour la réponse.

    oui tu as du t'en douter, la requete était :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT CODE  from table1 , table2 WHERE  SUBSTR(table1,1,2) = table2.code

  4. #4
    McM
    McM est déconnecté
    Expert confirmé

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Billets dans le blog
    4
    Par défaut
    D'après moi c'est encore mieux ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT CODE  FROM table1 , table2 WHERE  SUBSTR(table1.CODE,1,2) = table2.code

  5. #5
    Membre Expert
    Inscrit en
    Avril 2006
    Messages
    1 024
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 1 024
    Par défaut
    si ton champ code est d'un des types caractère (char, varchar etc..), l'index normal va fonctionner si tu utilise like car tu t'intéresse au premiers caractères:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT CODE  FROM table1 , table2 WHERE  table1.CODE like table2.code||'%'
    Sinon je crois qu'il faut s'assurer que ta session a le paramètre query_rewrite_enabled à TRUE si tu veux que les index-fonctions puissent êtres utilisés...

  6. #6
    Membre Expert Avatar de nuke_y
    Profil pro
    Indépendant en analyse de données
    Inscrit en
    Mai 2004
    Messages
    2 076
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Indépendant en analyse de données

    Informations forums :
    Inscription : Mai 2004
    Messages : 2 076
    Par défaut
    Citation Envoyé par remi4444
    Sinon je crois qu'il faut s'assurer que ta session a le paramètre query_rewrite_enabled à TRUE si tu veux que les index-fonctions puissent êtres utilisés...
    Ah bon ? Pourquoi ?

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

Discussions similaires

  1. Index sur datetime ne fonctionnant pas
    Par Pierrinot dans le forum Requêtes
    Réponses: 5
    Dernier message: 18/10/2004, 09h10
  2. Comment savoir s'il existe un index sur ma table ?
    Par CDRIK dans le forum Langage SQL
    Réponses: 3
    Dernier message: 06/10/2004, 09h58
  3. [Debutant][Tableau] Tableau indexé sur chaine de caractères
    Par SamRay1024 dans le forum Collection et Stream
    Réponses: 3
    Dernier message: 07/05/2004, 11h14
  4. n INDEXs sur chaque champ ou 1 seul INDEX sur n ch
    Par fourchette dans le forum Requêtes
    Réponses: 2
    Dernier message: 22/04/2004, 10h55
  5. [Sybase] Utilisation indexes sur table Proxy
    Par MashiMaro dans le forum Sybase
    Réponses: 2
    Dernier message: 20/02/2004, 10h20

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