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

Outils MySQL Discussion :

Optimize table sur table utilisée: LOCK ? COMMIT ?


Sujet :

Outils MySQL

  1. #1
    Membre habitué
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2003
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2003
    Messages : 120
    Points : 126
    Points
    126
    Par défaut Optimize table sur table utilisée: LOCK ? COMMIT ?
    Bonjour,

    J'utilise MySQL 4.0.20 sous windows 2000, tables en MyISAM.

    J'ai une table qui est contament sollicitée (en UPDATE) par un programme extérieur qui ne peut etre stoppé et je dois y ajouter un index.

    Pas de problème pour créer l'index en question mais pour qu'il soit vraiment efficace je dois egalement faire un OPTIMIZE TABLE. Or la fameuse table étant tout le temps ouverte, cette opération endommage la table.

    Y'a t'il un moyen de passer la modification ? en utilisant LOCK ou les transactions ?

    Merci de votre aide.

  2. #2
    Membre émérite Avatar de Maximil ian
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    2 622
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 2 622
    Points : 2 973
    Points
    2 973
    Par défaut
    Bonjour,

    Lors de l'ajout d'un index (et plus généralement quand on fait un ALTER) MySQL travaille sur une table temporaire qui est une copie de la table originale. Les accès à la table d'origine peuvent donc continuer pendant l'opération. Ensuite la table temporaire est renommée et l'ancienne est supprimée.

    Par ailleurs puisque l'index est entièrement recréé, je doute qu'un OPTIMIZE soit utile (il me semble que les statistiques d'index sont construites dès le début).
    Pensez au bouton

  3. #3
    Membre habitué
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2003
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2003
    Messages : 120
    Points : 126
    Points
    126
    Par défaut
    Citation Envoyé par Maximilian
    Par ailleurs puisque l'index est entièrement recréé, je doute qu'un OPTIMIZE soit utile (il me semble que les statistiques d'index sont construites dès le début).
    Je ne sais pas exactement ce qui se passe dans la méchanique interne de mysql mais j'ai remarqué qu'après un ALTER TABLE, les infos concernant les index dans phpMyAdmin semblent altérées (tableau index sur l'onglet Structure).
    Mais je fais peut-etre fausse route... A confirmer

    Sinon, j'ai trouver pour mon probleme en faisant:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    LOCK TABLES maTable;
    BEGIN;
    ALTER TABLE maTable ADD INDEX(champ);
    OPTIMIZE TABLE maTable;
    COMMIT;
    UNLOCK TABLES
    Je laisse le thread ouvert pour l'instant, j'aimerais en savoir plus sur cette histoire d'OPTIMIZE.
    Merci à toi Maximilian.

  4. #4
    Membre émérite Avatar de Maximil ian
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    2 622
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 2 622
    Points : 2 973
    Points
    2 973
    Par défaut
    Tu as raison, après vérification il semble que les statistiques d'un index ne sont pas initialisées lors de sa création.

    Par contre OPTIMIZE locke déjà lui-même la table lorsqu'il est exécuté :

    Note that MySQL locks the table during the time OPTIMIZE TABLE is running.
    http://dev.mysql.com/doc/refman/5.0/en/optimize-table.html
    Pensez au bouton

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

Discussions similaires

  1. [WD17] Table dans table dans table je pense ?!
    Par franck34matlab dans le forum WinDev
    Réponses: 8
    Dernier message: 08/07/2014, 14h06
  2. Question sur l'utilisation de l'espace des tables
    Par FREMEN dans le forum Débuter
    Réponses: 1
    Dernier message: 09/05/2008, 12h15
  3. Audit sur l'utilisation des champs de plusieurs tables
    Par Xavier2701 dans le forum Oracle
    Réponses: 1
    Dernier message: 29/03/2007, 08h26
  4. [18F452] Utiliser une Table sur un 18F
    Par MCASM dans le forum Autres architectures
    Réponses: 2
    Dernier message: 18/04/2006, 22h48
  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