Précédent   Forum des professionnels en informatique > Bases de données > MySQL
MySQL Forum d'entraide MySQL. Avant de poster -> FAQ MySQL, Tutoriels MySQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 05/11/2011, 16h07   #1
Membre habitué
 
Inscription : mai 2004
Messages : 383
Détails du profil
Informations forums :
Inscription : mai 2004
Messages : 383
Points : 129
Points : 129
Par défaut Une table et les index.

Salut,

J'ai créé une table user. Plutot que de vous la décrire voila un screenshot de phpMyadmin:


Voilà, j'ai donc une clef primaire user_id.
Mais je fais des recherches dans d'autres colonnes aussi, par exemple "user_email" en faisant:
select * from user where user_email = 'exemple@free.fr'.

Je ne comprends pas très bien la notion d'Index/Cardinalité. Est-ce qu'il me faut en ajouter sur le champs user_email pour que les recherches soit plus rapides ?

Si je souhaite créer un nouvel Index je tombe sur cette page:


Et là non plus, je ne sais pas quoi préciser...

Merci.
defacta est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/11/2011, 16h24   #2
Modérateur
 
Avatar de sevyc64
 
Homme Yves
Développeur informatique
Inscription : janvier 2007
Messages : 3 881
Détails du profil
Informations personnelles :
Nom : Homme Yves
Âge : 39
Localisation : France, Pyrénées Atlantiques (Aquitaine)

Informations professionnelles :
Activité : Développeur informatique

Informations forums :
Inscription : janvier 2007
Messages : 3 881
Points : 7 658
Points : 7 658
Un index améliore les recherches, mais consomme un peu de temps, de la mémoire et surtout du stockage, donc il faut qu'il soit justifié.

Si tu fais très régulièrement des recherche sur cette colonne tu peux effectivement ajouter un index sur la colonne. A savoir que l'index ne sera vraiment efficace que si les recherches que tu fais concerne le début du contenu de la colonne, style LIKE 'toto%'. Si ta recherche peut se trouver au milieu (LIKE '%toto%') ou à la fin du contenu, l'index est généralement peu efficace.

Dans ta fenêtre, tu donne un nom, si possible explicite, à ton index (c'est plus pratique si tu veux ensuite le modifier ou supprimer), par exemple Idx_TaColonne, puis tu indique sur quelle colonne il porte.
__________________
Sevyc64 --- Le partage est notre force

NON AU LANGAGE SMS & FAUTES VOLONTAIRES SUR LES FORUMS
sevyc64 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/11/2011, 16h33   #3
Membre habitué
 
Inscription : mai 2004
Messages : 383
Détails du profil
Informations forums :
Inscription : mai 2004
Messages : 383
Points : 129
Points : 129
Citation:
Envoyé par sevyc64 Voir le message
Un index améliore les recherches, mais consomme un peu de temps, de la mémoire et surtout du stockage, donc il faut qu'il soit justifié.

Dans ta fenêtre, tu donne un nom, si possible explicite, à ton index (c'est plus pratique si tu veux ensuite le modifier ou supprimer), par exemple Idx_TaColonne, puis tu indique sur quelle colonne il porte.
ok, je pense avoir compris
Pour la taille, il faut préciser quelque chose ?

Sinon, j'ai d'autres tables qui ont user_id dans une colonne, par exemple la table book va avoir un champs book_user_id.

Donc je vais avoir souvent des recherches de type:
select * from book where book_user_id = 3

Pour avoir la liste des "books" écrits par le user dont l'id est 3...Et dans ce cas il me faut créer un index sur book_user_id ?

merci.
defacta est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/11/2011, 17h39   #4
Modérateur
 
Avatar de sevyc64
 
Homme Yves
Développeur informatique
Inscription : janvier 2007
Messages : 3 881
Détails du profil
Informations personnelles :
Nom : Homme Yves
Âge : 39
Localisation : France, Pyrénées Atlantiques (Aquitaine)

Informations professionnelles :
Activité : Développeur informatique

Informations forums :
Inscription : janvier 2007
Messages : 3 881
Points : 7 658
Points : 7 658
Je ne connais pas particulièrement MySql, pour la taille, je ne saurais dire. J'imagine qu'il doit y avoir une valeur par défaut si tu ne la renseigne pas.

Là encore, je ne connais pas les spécificités de MySql, mais généralement, les clés primaires ont toujours un index d'associé, il n'est pas nécessaire d'en créer un explicitement. C'est aussi normalement le cas des clés étrangères quand elles sont déclarées en tant que telles.
__________________
Sevyc64 --- Le partage est notre force

NON AU LANGAGE SMS & FAUTES VOLONTAIRES SUR LES FORUMS
sevyc64 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/11/2011, 20h46   #5
Membre habitué
 
Inscription : mai 2004
Messages : 383
Détails du profil
Informations forums :
Inscription : mai 2004
Messages : 383
Points : 129
Points : 129
Citation:
Envoyé par sevyc64 Voir le message
Là encore, je ne connais pas les spécificités de MySql, mais généralement, les clés primaires ont toujours un index d'associé, il n'est pas nécessaire d'en créer un explicitement. C'est aussi normalement le cas des clés étrangères quand elles sont déclarées en tant que telles.
Le problème c'est que user_id dans la table book n'est pas associé à une clef, elle n'a que le nom de la clef primaire de la table user...c'est juste une colonne de type int(8).

Quelqu'un sait si sous MySql je peux associer user_id de la table book à user_id de la table user ?

Merci.
defacta est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 06/11/2011, 10h12   #6
Modérateur
 
Avatar de CinePhil
 
Homme Philippe Leménager
Ingénieur d'études en informatique
Inscription : août 2006
Messages : 11 029
Détails du profil
Informations personnelles :
Nom : Homme Philippe Leménager
Âge : 48
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations professionnelles :
Activité : Ingénieur d'études en informatique
Secteur : Enseignement

Informations forums :
Inscription : août 2006
Messages : 11 029
Points : 18 333
Points : 18 333
Envoyer un message via MSN à CinePhil
Citation:
Envoyé par defacta Voir le message
Le problème c'est que user_id dans la table book n'est pas associé à une clef, elle n'a que le nom de la clef primaire de la table user...c'est juste une colonne de type int(8).
Quelqu'un sait si sous MySql je peux associer user_id de la table book à user_id de la table user ?[/QUOTE]
Pour bénéficier des contraintes de clés étrangères, il faut utiliser le moteur InnoDB.
Les clés étrangères doivent être indexées. Lorsque tu déclare les clés étrangères à la création de la table, je crois que l'indexation est automatique mais comme tu as apparemment créé tes tables en MyISAM, tu devras d'abord indexer les colonnes puis poser les contraintes de clés étrangères.
Pour ce faire, une fois que tu auras passé ta table en InnoDB, tu verras une option supplémentaire apparaître dans phpMyAdmin sous la liste des colonnes : "Gestion des relations". Ensuite, tu verras que l'interface de cette option est très simple.

Pour t'aider dans le choix des index, va lire l'article de SQLPro.
__________________
Philippe Leménager. Ingénieur d'étude à l'École Nationale de Formation Agronomique.
Mon blog sur la conception des BDD, le langage SQL, le PHP avec Zend Framework...
« Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
À la maison comme au bureau, j'utilise Mandriva Linux ou Mageïa ! Soutenons l'industrie logicielle française !
Linuxiens, comptez-vous !
CinePhil est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 16h43.


 
 
 
 
Partenaires

Hébergement Web