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

Langage SQL Discussion :

Indexation d'un champ VARCHAR


Sujet :

Langage SQL

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 4
    Points : 5
    Points
    5
    Par défaut Indexation d'un champ VARCHAR
    Bonjour,

    J'ai actuellement une table contenant 4 champs INT et 1 champ VARCHAR(50).

    Cette table est uniquement utilisée en faisant des requêtes de recherche sur le champ VARCHAR du type :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM maTable WHERE champVarchar REGEXP "searchValue" LIMIT 0,10
    Je voulais indexer le champ VARCHAR afin d'accélérer mes requêtes.

    Est-ce pertinent d'indexer un champ VARCHAR surtout si je ne fais pas des recherches exactes mais des recherches avec REGEXP ?

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 103
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 103
    Points : 28 394
    Points
    28 394
    Par défaut
    Cela aurait de l'intérêt si les recherches étaient de la forme...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE champVarchar LIKE 'searchValue%'
    Autrement cela n'apportera rien

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 4
    Points : 5
    Points
    5
    Par défaut
    Merci beaucoup pour la réponse, je vais changer mes requêtes et indexer mon champ.

    Est-ce que cela aura un effet significatif ou cela sera plutôt négligeable (la table contient environ 2000 enregistrements).

    Et à ton avis vaut-il mieux laisser ce champ en VARCHAR ou le mettre en TEXT afin d'améliorer encore un peu les performances ?

    [EDIT] Autant pour moi j'avais pas vu qu'il n'y avait que un seul "%" dans le LIKE. Donc en gros ca ne marche que si je veut faire des requêtes en cherchant sur le début d'une chaine... Dommage.

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    84
    Détails du profil
    Informations personnelles :
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Novembre 2009
    Messages : 84
    Points : 80
    Points
    80
    Par défaut
    Non pas forcément le début d'une chaine.
    Tu peux aussi mettre un % au début de la chaine.
    Un % correspond à un nombre entre 0 et n caractères.
    Un _ correspond à un seul caractère.
    Tu peux les placer où tu veux et en mettre autant que tu désires (bien que mettre plusieurs % à la suite n'ait pas d'intérêt ).

    Pour le reste je laisse parler les pros

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

Discussions similaires

  1. Indexation d'un champ VARCHAR
    Par delta14 dans le forum Requêtes
    Réponses: 0
    Dernier message: 11/08/2010, 18h38
  2. Insertion d'un nombre dans un champs varchar ?
    Par Tchinkatchuk dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 07/04/2005, 15h17
  3. Extraction de chiffres d'un champs VARCHAR vers un NUM
    Par midnight77 dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 30/11/2004, 10h52
  4. Réponses: 1
    Dernier message: 03/11/2004, 14h55
  5. 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

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