Rechercher dans le manuel MySQL
8.6.3 Optimizing REPAIR TABLE Statements
        REPAIR TABLE for
        MyISAM tables is similar to using
        myisamchk for repair operations, and some of
        the same performance optimizations apply:
- myisamchk has variables that control memory allocation. You may be able to its improve performance by setting these variables, as described in Section 4.6.4.6, “myisamchk Memory Usage”. 
- For - REPAIR TABLE, the same principle applies, but because the repair is done by the server, you set server system variables instead of myisamchk variables. Also, in addition to setting memory-allocation variables, increasing the- myisam_max_sort_file_sizesystem variable increases the likelihood that the repair will use the faster filesort method and avoid the slower repair by key cache method. Set the variable to the maximum file size for your system, after checking to be sure that there is enough free space to hold a copy of the table files. The free space must be available in the file system containing the original table files.
Suppose that a myisamchk table-repair operation is done using the following options to set its memory-allocation variables:
--key_buffer_size=128M --myisam_sort_buffer_size=256M
--read_buffer_size=64M --write_buffer_size=64MSome of those myisamchk variables correspond to server system variables:
| myisamchk Variable | System Variable | 
|---|---|
| key_buffer_size | key_buffer_size | 
| myisam_sort_buffer_size | myisam_sort_buffer_size | 
| read_buffer_size | read_buffer_size | 
| write_buffer_size | none | 
        Each of the server system variables can be set at runtime, and
        some of them
        (myisam_sort_buffer_size,
        read_buffer_size) have a
        session value in addition to a global value. Setting a session
        value limits the effect of the change to your current session
        and does not affect other users. Changing a global-only variable
        (key_buffer_size,
        myisam_max_sort_file_size)
        affects other users as well. For
        key_buffer_size, you must take
        into account that the buffer is shared with those users. For
        example, if you set the myisamchk
        key_buffer_size variable to 128MB, you could
        set the corresponding
        key_buffer_size system variable
        larger than that (if it is not already set larger), to permit
        key buffer use by activity in other sessions. However, changing
        the global key buffer size invalidates the buffer, causing
        increased disk I/O and slowdown for other sessions. An
        alternative that avoids this problem is to use a separate key
        cache, assign to it the indexes from the table to be repaired,
        and deallocate it when the repair is complete. See
        Section 8.10.2.2, “Multiple Key Caches”.
      
        Based on the preceding remarks, a REPAIR
        TABLE operation can be done as follows to use settings
        similar to the myisamchk command. Here a
        separate 128MB key buffer is allocated and the file system is
        assumed to permit a file size of at least 100GB.
      
- REPAIR TABLE tbl_name ;
        If you intend to change a global variable but want to do so only
        for the duration of a REPAIR
        TABLE operation to minimally affect other users, save
        its value in a user variable and restore it afterward. For
        example:
      
- REPAIR TABLE tbl_name ;
        The system variables that affect REPAIR
        TABLE can be set globally at server startup if you
        want the values to be in effect by default. For example, add
        these lines to the server my.cnf file:
      
[mysqld]
myisam_sort_buffer_size=256M
key_buffer_size=1G
myisam_max_sort_file_size=100G
        These settings do not include
        read_buffer_size. Setting
        read_buffer_size globally to a
        large value does so for all sessions and can cause performance
        to suffer due to excessive memory allocation for a server with
        many simultaneous sessions.
Nederlandse vertaling
U hebt gevraagd om deze site in het Nederlands te bezoeken. Voor nu wordt alleen de interface vertaald, maar nog niet alle inhoud.Als je me wilt helpen met vertalingen, is je bijdrage welkom. Het enige dat u hoeft te doen, is u op de site registreren en mij een bericht sturen waarin u wordt gevraagd om u toe te voegen aan de groep vertalers, zodat u de gewenste pagina's kunt vertalen. Een link onderaan elke vertaalde pagina geeft aan dat u de vertaler bent en heeft een link naar uw profiel.
Bij voorbaat dank.
Document heeft de 26/06/2006 gemaakt, de laatste keer de 26/10/2018 gewijzigd
Bron van het afgedrukte document:https://www.gaudry.be/nl/mysql-rf-repair-table-optimization.html
De infobrol is een persoonlijke site waarvan de inhoud uitsluitend mijn verantwoordelijkheid is. De tekst is beschikbaar onder CreativeCommons-licentie (BY-NC-SA). Meer info op de gebruiksvoorwaarden en de auteur.
Referenties
Deze verwijzingen en links verwijzen naar documenten die geraadpleegd zijn tijdens het schrijven van deze pagina, of die aanvullende informatie kunnen geven, maar de auteurs van deze bronnen kunnen niet verantwoordelijk worden gehouden voor de inhoud van deze pagina.
De auteur van deze site is als enige verantwoordelijk voor de manier waarop de verschillende concepten, en de vrijheden die met de referentiewerken worden genomen, hier worden gepresenteerd. Vergeet niet dat u meerdere broninformatie moet doorgeven om het risico op fouten te verkleinen.
 
  
  
  
 