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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 4
    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 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    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 138
    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
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 4
    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 actif
    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
    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, 19h38
  2. Insertion d'un nombre dans un champs varchar ?
    Par Tchinkatchuk dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 07/04/2005, 16h17
  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, 11h52
  4. Réponses: 1
    Dernier message: 03/11/2004, 15h55
  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, 11h55

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