manuel mysql 4.1.x − version française -...

672
Manuel MySQL 4.1.x - Version Française http://www.nexen.net Copyright (c) 2002-2003 MySQL AB

Upload: truongnga

Post on 06-Dec-2018

226 views

Category:

Documents


0 download

TRANSCRIPT

  • Manuel MySQL 4.1.x Version Franaisehttp://www.nexen.net

    Copyright (c) 20022003 MySQL AB

  • Sommaire 1 Informations gnrales .................................................................................................................1

    1.1 A propos du manuel..........................................................................................................1 1.1.1 Conventions utilises dans ce manuel.....................................................................2

    1.2 Qu'est ce que MySQL?.....................................................................................................3 1.2.1 Histoire de MySQL...................................................................................................4 1.2.2 Les fonctionnalits principales de MySQL...............................................................5 1.2.3 Jusqu' quel point MySQL est il stable ?.................................................................7 1.2.4 Quelles tailles de tables supporte MySQL ?............................................................8 1.2.5 Compatibilit an 2000..............................................................................................9

    1.3 Qui est MySQL AB ?.......................................................................................................10 1.3.1 Les services et le modle d'affaire de MySQL AB.................................................10

    1.3.1.1 Support..........................................................................................................11 1.3.1.2 Formation et certification...............................................................................11 1.3.1.3 Conseil..........................................................................................................11 1.3.1.4 Licences commerciales.................................................................................12 1.3.1.5 Partenariats...................................................................................................12 1.3.1.6 Publicit.........................................................................................................12

    1.3.2 Contacts.................................................................................................................13 1.4 Support MySQL et licences............................................................................................14

    1.4.1 Support propos par MySQL AB............................................................................14 1.4.2 Copyrights et licences utilises par MySQL...........................................................14 1.4.3 Licences MySQL....................................................................................................15

    1.4.3.1 Utiliser MySQL avec la licence commerciale................................................15 1.4.3.2 Utiliser MySQL sous licence GPL libre.........................................................16

    1.4.4 Logos MySQL AB et marque dpose...................................................................17 1.4.4.1 Le logo original de MySQL............................................................................17 1.4.4.2 Logos MySQL qui peuvent tre utiliss dans autorisation pralable............17 1.4.4.3 Quand avez vous besoin d'autorisation pour utiliser le logo MySQL?..........17 1.4.4.4 Logos de partenariat MySQL AB..................................................................18 1.4.4.5 Utiliser le nom MySQL sur des documents imprims ou des

    prsentations.................................................................................................18 1.4.4.6 Utilisation du nom MySQL dans un nom de socit ou de produit...............18

    1.5 MySQL 4.0 In A Nutshell.................................................................................................18 1.5.1 Fonctionnalits disponibles depuis MySQL 4.0.....................................................19 1.5.2 MySQL Server intgr (embedded).......................................................................20

    1.6 MySQL 4.1 In A Nutshell.................................................................................................20 1.6.1 Fonctionnalits disponibles depuis MySQL 4.1.....................................................20 1.6.2 Phases de publication............................................................................................21 1.6.3 Utilisation immdiate en production.......................................................................22 1.6.4 MySQL 5.0, The Next Development Release........................................................22

    1.7 Sources d'informations MySQL.......................................................................................22 1.7.1 Listes de diffusion MySQL.....................................................................................22

    1.7.1.1 Les listes de diffusions de MySQL................................................................22 1.7.1.2 Poser des questions ou rapporter un bogue.................................................24 1.7.1.3 Comment rapporter un bogue ou un problme.............................................25 1.7.1.4 Conseils pour rpondre sur la liste de diffusion............................................28

    1.7.2 Support de la communaut MySQL sur IRC (Internet Relay Chat).......................29 1.8 Quels standards respecte MySQL?................................................................................29

    1.8.1 Quels standards suit MySQL ?..............................................................................30 1.8.2 Excuter MySQL en mode ANSI............................................................................30 1.8.3 Extensions de MySQL la norme ANSI SQL92....................................................30 1.8.4 Diffrences de MySQL avec ANSI SQL92.............................................................32

    Manuel MySQL 4.1.x Version Franaise

    i

  • Sommaire 1 Informations gnrales

    1.8.4.1 Sous slections (Sub SELECT s).................................................................33 1.8.4.2 SELECT INTO TABLE..................................................................................33 1.8.4.3 Transactions et oprations atomiques..........................................................34 1.8.4.4 Procdures stockes et triggers....................................................................36 1.8.4.5 Les cls trangres.......................................................................................36 1.8.4.6 Les vues........................................................................................................37 1.8.4.7 '' comme dbut de commentaire...............................................................38

    1.8.5 Erreurs connues, et limitations de MySQL.............................................................38 1.8.5.1 Erreurs connues en 3.23 et corriges ultrieurement...................................38 1.8.5.2 Bugs connus / limitations de MySQL............................................................39

    1.9 Les volutions de MySQL (la liste des tches)...............................................................42 1.9.1 New Features Planned For 4.1..............................................................................42 1.9.2 New Features Planned For 5.0..............................................................................42 1.9.3 Nouvelles fonctionnalits prvues pour 5.1...........................................................43 1.9.4 Ce qui doit tre fait dans un futur proche...............................................................44 1.9.5 Ce qui est prvu moyen terme............................................................................46 1.9.6 Ce qui n'est pas prvu...........................................................................................47

    1.10 Comparatif de MySQL avec les autres serveurs SQL..................................................47 1.10.1 MySQL face mSQL...........................................................................................47

    1.10.1.1 Comment convertir des outils mSQL pour MySQL.....................................49 1.10.1.2 Diffrences entre les protocoles de communication de mSQL et de

    MySQL..........................................................................................................50 1.10.1.3 Comparatif des syntaxes SQL de mSQL 2.0 et MySQL.............................50

    1.10.2 Comparatif de MySQL avec PostgreSQL............................................................53 1.10.2.1 Stratgies de dveloppement de MySQL et PostgreSQL...........................53 1.10.2.2 Comparaison des fonctionnalits de MySQL et PostgreSQL.....................54 1.10.2.3 Performances compares de MySQL et PostgreSQL................................57

    2 Installation de MySQL.................................................................................................................61 2.1 Installation standard rapide de MySQL...........................................................................61

    2.1.1 Installer MySQL sous Linux...................................................................................61 2.1.2 Installer MySQL sous Windows.............................................................................62

    2.1.2.1 Installation des binaires.................................................................................63 2.1.2.2 Prparation de l'environnement MySQL de Windows...................................63 2.1.2.3 Dmarrer le serveur pour la premire fois....................................................64

    2.1.3 Installer MySQL sur Mac OS X..............................................................................65 2.1.4 Installer MySQL sur NetWare................................................................................66

    2.1.4.1 Installer les excutables MySQL pour NetWare...........................................66 2.2 Notes gnrales propos de l'installation......................................................................67

    2.2.1 Comment obtenir MySQL ?....................................................................................67 2.2.2 Vrifier l'intgrit des paquets avec MD5 ou GnuPG.............................................67 2.2.3 Systmes d'exploitation supports par MySQL.....................................................69 2.2.4 Quelle version de MySQL utiliser ?........................................................................71 2.2.5 Dispositions d'installation.......................................................................................73 2.2.6 Quand et comment sont publies les nouvelles versions......................................74 2.2.7 Politique de publication : aucun bug connu dans les versions...............................74 2.2.8 Binaires compils par MySQL AB..........................................................................75 2.2.9 Installer MySQL partir d'une distribution binaire.................................................77

    2.3 Installer MySQL partir des sources..............................................................................79 2.3.1 Vue d'ensemble de l'installation rapide..................................................................80 2.3.2 Appliquer des patches............................................................................................82

    Manuel MySQL 4.1.x Version Franaise

    ii

  • Sommaire 2 Installation de MySQL

    2.3.3 Options habituelles de configure............................................................................82 2.3.4 Installer partir de l'arbre source de dveloppement............................................84 2.3.5 Problmes de compilation?....................................................................................85 2.3.6 Notes relatives aux MITpthreads.........................................................................87 2.3.7 La distribution source Windows.............................................................................88

    2.4 Configuration aprs l'installation, et tests........................................................................89 2.4.1 Problmes d'excution de mysql_install_db..........................................................92 2.4.2 Problmes de dmarrage du serveur MySQL........................................................93 2.4.3 Lancer et arrter MySQL automatiquement...........................................................95

    2.5 Changer de version de MySQL.......................................................................................96 2.5.1 Passer de la version 4.0 la version 4.1...............................................................96 2.5.2 Prparer le passage de version 4.0 en 4.1............................................................97 2.5.3 Passer de la version 3.23 la version 4.0.............................................................97 2.5.4 Passer de la version 3.22 la version 3.23.........................................................100 2.5.5 Passer de la version 3.21 la version 3.22.........................................................101 2.5.6 Passer de la version 3.20 la version 3.21.........................................................101 2.5.7 Migrer depuis une autre architecture...................................................................102

    2.6 Notes spcifiques aux systmes d'exploitation.............................................................103 2.6.1 Notes relatives Linux (toutes versions).............................................................103

    2.6.1.1 Notes relatives Linux pour les distributions binaires................................106 2.6.1.2 Notes relatives Linux x86.........................................................................108 2.6.1.3 Notes relatives Linux SPARC..................................................................108 2.6.1.4 Notes relatives Linux Alpha......................................................................109 2.6.1.5 Note relative Linux PowerPC...................................................................109 2.6.1.6 Notes relatives Linux MIPS......................................................................109 2.6.1.7 Notes relatives Linux IA64.......................................................................110

    2.6.2 Notes relatives Windows...................................................................................110 2.6.2.1 Dmarrer MySQL sous Windows 95, 98 ou Me..........................................110 2.6.2.2 Dmarrer MySQL sur Windows NT, 2000 ou XP........................................111 2.6.2.3 Faire fonctionner MySQL sous Windows....................................................112 2.6.2.4 Connexion un serveur MySQL distants, sous Windows avec SSH.........113 2.6.2.5 Paratger les donnes entre plusieurs disque sous Windows......................113 2.6.2.6 Compiler les clients MySQL sous Windows................................................114 2.6.2.7 MySQL pour Windows face MySQL pour Unix........................................114

    2.6.3 Remarques pour Solaris......................................................................................116 2.6.3.1 Notes relatives Solaris 2.7/2.8.................................................................118 2.6.3.2 Remarques pour Solaris x86.......................................................................119

    2.6.4 Notes relatives BSD..........................................................................................120 2.6.4.1 Notes relatives FreeBSD..........................................................................120 2.6.4.2 Notes concernant NetBSD..........................................................................121 2.6.4.3 Notes relatives OpenBSD 2.5..................................................................121 2.6.4.4 Notes relatives OpenBSD 2.8..................................................................121 2.6.4.5 Notes relatives aux versions 2.x de BSD/OS..............................................121 2.6.4.6 Notes relatives aux versions 3.x de BSD/OS..............................................122 2.6.4.7 Notes relatives aux versions 4.x de BSD/OS..............................................122

    2.6.5 Notes relatives Mac OS X.................................................................................123 2.6.5.1 Mac OS X 10.x............................................................................................123 2.6.5.2 Mac OS X Server 1.2 (Rhapsody)...............................................................123

    2.6.6 Notes sur les autres Unix.....................................................................................123 2.6.6.1 Notes relatives HPUX pour les distributions binaires.............................123 2.6.6.2 Notes relatives la version 10.20 de HPUX.............................................124

    Manuel MySQL 4.1.x Version Franaise

    iii

  • Sommaire 2 Installation de MySQL

    2.6.6.3 HPUX Version 11.x Notes.........................................................................124 2.6.6.4 Notes relatives IBMAIX..........................................................................125 2.6.6.5 Notes relatives SunOS 4..........................................................................127 2.6.6.6 Notes pour AlphaDECUNIX (Tru64).......................................................127 2.6.6.7 Notes pour AlphaDECOSF/1..................................................................128 2.6.6.8 Notes relatives SGI Irix............................................................................129 2.6.6.9 Notes pour Caldera (SCO)..........................................................................130 2.6.6.10 Notes relatives la version 7.0 fr Caldera (SCO) Unixware.....................131

    2.6.7 Notes relatives OS/2.........................................................................................132 2.6.8 Notes relatives BeOS........................................................................................132 2.6.9 Notes relatives Novell NetWare........................................................................133

    2.7 Commentaires sur l'installation de Perl.........................................................................133 2.7.1 Installer Perl sur Unix...........................................................................................133 2.7.2 Installer ActiveState Perl sur Windows................................................................134 2.7.3 Installer la distribution Perl de MySQL sous Windows.........................................134 2.7.4 Problmes lors de l'utilisation des interfaces Perl DBI et DBD............................134

    3 Tutoriels d'introduction .............................................................................................................137 3.1 Connexion et dconnexion au serveur.........................................................................137 3.2 Entrer des requtes......................................................................................................138 3.3 Cration et utilisation d'une base de donnes..............................................................140

    3.3.1 Crer et slectionner une base de donnes........................................................141 3.3.2 Cration d'une table.............................................................................................141 3.3.3 Charger des donnes dans une table..................................................................143 3.3.4 Rcuprer des informations partir d'une table..................................................144

    3.3.4.1 Slectionner toutes les donnes.................................................................144 3.3.4.2 Slectionner des lignes particulires...........................................................145 3.3.4.3 Slectionner des colonnes particulires......................................................145 3.3.4.4 Trier les enregistrements............................................................................146 3.3.4.5 Calcul sur les Dates....................................................................................147 3.3.4.6 Travailler avec la valeur NULL....................................................................149 3.3.4.7 Recherche de modles...............................................................................149 3.3.4.8 Compter les lignes......................................................................................151 3.3.4.9 Utiliser plus d'une table...............................................................................153

    3.4 Obtenir des informations propos des bases de donnes et des tables.....................154 3.5 Exemples de requtes usuelles....................................................................................155

    3.5.1 La valeur maximale d'une colonne.......................................................................156 3.5.2 La ligne contenant le maximum d'une certaine colonne......................................156 3.5.3 Maximum d'une colonne par groupe....................................................................156 3.5.4 La ligne contenant la plus grande valeur d'un certain champ par rapport un

    groupe.....................................................................................................................156 3.5.5 Utiliser les variables utilisateur.............................................................................157 3.5.6 Utiliser les clefs trangres..................................................................................158 3.5.7 Recherche sur deux clefs.....................................................................................158 3.5.8 Calcul du nombre de visites par jour....................................................................159 3.5.9 Utiliser AUTO_INCREMENT................................................................................159

    3.6 Utilisation de mysql en mode batch..............................................................................160 3.7 Requtes du projet Twin...............................................................................................161

    3.7.1 Trouver tous les jumeaux rpondant aux critres................................................162 3.7.2 Afficher une table avec l'tat des paires de jumeaux...........................................163

    3.8 Utilisation de MySQL avec Apache...............................................................................164

    Manuel MySQL 4.1.x Version Franaise

    iv

  • Sommaire 4 Administration du serveur ........................................................................................................165

    4.1 Configuration de MySQL...............................................................................................165 4.1.1 Options de ligne de commande de mysqld..........................................................165 4.1.2 Fichier d'options my.cnf.......................................................................................169 4.1.3 Installer plusieurs serveurs sur la mme machine...............................................171 4.1.4 Faire fonctionner plusieurs serveurs MySQL sur la mme machine....................172

    4.2 Rgles de scurit et droits d'accs au serveur MySQL..............................................174 4.2.1 Instructions gnrales de scurit.......................................................................174 4.2.2 Comment protger MySQL contre les pirates......................................................176 4.2.3 Options de dmarrage qui concernent la scurit...............................................178 4.2.4 Problmes de scurit avec LOAD DATA LOCAL...............................................178 4.2.5 Rle du systme de privilges.............................................................................179 4.2.6 Comment fonctionne le systme de droits...........................................................179 4.2.7 Droits fournis par MySQL.....................................................................................182 4.2.8 Se connecter au serveur MySQL.........................................................................184 4.2.9 Contrle d'accs, tape 1 : Vrification de la connexion.....................................184 4.2.10 Contrle d'accs, tape 2 : Vrification de la requte........................................187 4.2.11 Causes des erreurs Access denied...................................................................189

    4.3 Gestion des comptes utilisateurs de MySQL................................................................192 4.3.1 Syntaxe de GRANT et REVOKE..........................................................................193 4.3.2 Nom d'utilisateurs MySQL et mots de passe.......................................................196 4.3.3 Quand les modifications de privilges prennentils effets ?................................197 4.3.4 Cration des premiers droits MySQL...................................................................198 4.3.5 Ajouter de nouveaux utilisateurs MySQL..........................................................199 4.3.6 Limiter les ressources utilisateurs........................................................................201 4.3.7 Configurer les mots de passe..............................................................................202 4.3.8 Garder vos mots de passe en lieu sr.................................................................203 4.3.9 Utilisation des connexions scurises.................................................................204

    4.3.9.1 Introduction aux connexions scurises.....................................................204 4.3.9.2 Pr requis aux connexions scurises........................................................204 4.3.9.3 Configurer les certificats SSL pour MySQL.................................................205 4.3.9.4 Options de GRANT.....................................................................................207

    4.4 Prvention des dsastres et restauration.....................................................................208 4.4.1 Sauvegardes de base de donnes......................................................................208 4.4.2 Syntaxe de BACKUP TABLE...............................................................................209 4.4.3 Syntaxe de RESTORE TABLE............................................................................209 4.4.4 Syntaxe de CHECK TABLE.................................................................................210 4.4.5 Syntaxe de REPAIR TABLE................................................................................211 4.4.6 Utilisation de myisamchk pour la maintenance des tables et leur

    recouvrement..........................................................................................................212 4.4.6.1 Syntaxe de l'utilitaire myisamchk................................................................213 4.4.6.2 Options gnrales de myisamchk...............................................................214 4.4.6.3 Options de vrifications pour myisamchk....................................................215 4.4.6.4 Options de rparation de myisamchk..........................................................215 4.4.6.5 Autres options de myisamchk.....................................................................216 4.4.6.6 Utilisation de la mmoire par myisamchk....................................................217 4.4.6.7 Utiliser myisamchk pour restaurer une table...............................................217 4.4.6.8 Comment vrifier la cohrence d'une table.................................................218 4.4.6.9 Comment rparer des tables.......................................................................219 4.4.6.10 Optimisation de tables...............................................................................221

    4.4.7 Mettre en place un rgime d'entretien de MySQL................................................221 4.4.8 Obtenir des informations sur une table................................................................222

    Manuel MySQL 4.1.x Version Franaise

    v

  • Sommaire 4 Administration du serveur

    4.5 Rfrence de langage d'administration de la base de donnes...................................226 4.5.1 Syntaxe de OPTIMIZE TABLE.............................................................................226 4.5.2 Syntaxe de ANALYZE TABLE.............................................................................226 4.5.3 Syntaxe de FLUSH..............................................................................................227 4.5.4 Syntaxe de la commande RESET........................................................................227 4.5.5 Syntaxe de KILL...................................................................................................228 4.5.6 Syntaxe de SHOW...............................................................................................228

    4.5.6.1 Obtenir des informations sur les bases, tables, colonnes et index.............229 4.5.6.2 SHOW TABLE STATUS.............................................................................230 4.5.6.3 Syntaxe de SHOW STATUS.......................................................................230 4.5.6.4 Syntaxe de SHOW VARIABLES.................................................................232 4.5.6.5 Syntaxe de SHOW LOGS...........................................................................239 4.5.6.6 Syntaxe de SHOW PROCESSLIST............................................................239 4.5.6.7 SHOW GRANTS.........................................................................................241 4.5.6.8 Syntaxe de SHOW CREATE TABLE..........................................................241 4.5.6.9 SHOW WARNINGS | ERRORS..................................................................241 4.5.6.10 SHOW TABLE TYPES..............................................................................241 4.5.6.11 SHOW PRIVILEGES.................................................................................242

    4.6 Localisation de MySQL et utilisation internationale......................................................242 4.6.1 Le jeu de caractres utilis pour les donnes et le stockage...............................242

    4.6.1.1 Jeu de caractres allemand........................................................................243 4.6.2 Langue des messages d'erreurs..........................................................................244 4.6.3 Ajouter un nouveau jeu de caractres.................................................................244 4.6.4 Le tableau de dfinition des caractres...............................................................245 4.6.5 Support d'assemblage des chanes.....................................................................246 4.6.6 Support des caractres multioctets....................................................................246 4.6.7 Problmes avec les jeux de caractres...............................................................246

    4.7 Scripts serveur MySQL et utilitaires..............................................................................247 4.7.1 Prsentation des scripts serveurs et des utilitaires..............................................247 4.7.2 safe_mysqld , le script pre de mysqld................................................................247 4.7.3 mysqld_multi , un programme pour grer plusieurs serveurs MySQL.................249 4.7.4 myisampack , le gnrateur de tables MySQL compresses en lecture seule....251 4.7.5 mysqldmax , la version tendue du serveur mysqld..........................................256

    4.8 MySQL Scripts clients et utilitaires................................................................................257 4.8.1 Prsentation des scripts serveurs et utilitaires.....................................................257 4.8.2 mysql , l'outil en ligne de commande...................................................................258 4.8.3 mysqladmin , administrer un serveur MySQL......................................................263 4.8.4 Utiliser mysqlcheck pour l'entretien et la rparation.............................................264 4.8.5 mysqldump , exporter les structures de tables et les donnes............................266 4.8.6 mysqlhotcopy , copier les bases et tables MySQL...............................................270 4.8.7 mysqlimport , importer des donnes depuis des fichiers texte............................271 4.8.8 Afficher les bases, tables et colonnes..................................................................272 4.8.9 mysql_config lit les options de compilations du client MySQL.............................273 4.8.10 perror , expliquer les codes d'erreurs.................................................................274 4.8.11 Comment excuter des commandes SQL depuis un fichier texte.....................274

    4.9 Les fichiers de log de MySQL.......................................................................................274 4.9.1 Le log d'erreurs....................................................................................................275 4.9.2 Le log gnral de requtes..................................................................................275 4.9.3 Le log de modification..........................................................................................275 4.9.4 Le log binaire........................................................................................................276 4.9.5 Le log des requtes lentes...................................................................................278

    Manuel MySQL 4.1.x Version Franaise

    vi

  • Sommaire 4 Administration du serveur

    4.9.6 Entretien des fichiers de log.................................................................................278 4.10 Rplication de MySQL................................................................................................279

    4.10.1 Introduction la rplication................................................................................279 4.10.2 Prsentation de l'implmentation de la rplication.............................................279 4.10.3 Comment mettre en place la rplication.............................................................280 4.10.4 Fonctionnalits de la rplication et problmes connus......................................282 4.10.5 Options de rplication dans le fichier my.cnf......................................................284 4.10.6 Commandes SQL lies la rplication..............................................................287 4.10.7 FAQ de la rplication..........................................................................................288 4.10.8 Correction de problmes courants.....................................................................292

    5 Optimisation de MySQL............................................................................................................294 5.1 Vue d'ensemble de l'optimisation..................................................................................294

    5.1.1 Limitations et inconvnients des choix conceptuels de MySQL...........................294 5.1.2 Portabilit.............................................................................................................295 5.1.3 Pour quoi avons nous utilis MySQL ?................................................................296 5.1.4 La suite de tests MySQL......................................................................................297 5.1.5 Utiliser vos propres tests de performance............................................................298

    5.2 Optimisation des SELECT s et autres requtes...........................................................299 5.2.1 Syntaxe de EXPLAIN (Obtenir des informations sur les SELECT ).....................299 5.2.2 Mesurer les performances d'une requte............................................................304 5.2.3 Vitesse des requtes SELECT.............................................................................304 5.2.4 Comment MySQL optimise les clauses WHERE.................................................305 5.2.5 Comment MySQL optimise la clause DISTINCT.................................................306 5.2.6 Comment MySQL optimise LEFT JOIN et RIGHT JOIN......................................306 5.2.7 Comment MySQL optimise les clauses ORDER BY............................................307 5.2.8 Comment MySQL optimise la clause LIMIT.........................................................308 5.2.9 Vitesse des requtes INSERT.............................................................................309 5.2.10 Vitesses des commandes UPDATE...................................................................310 5.2.11 Rapidit des requtes DELETE.........................................................................311 5.2.12 Autres conseils d'optimisation............................................................................311

    5.3 Verrouillage de tables...................................................................................................313 5.3.1 Comment MySQL verrouille les tables.................................................................313 5.3.2 Problme de verrouillage de tables......................................................................314

    5.4 Optimisation de la structure de la base de donnes.....................................................315 5.4.1 Conception...........................................................................................................315 5.4.2 Rendre vos tables aussi compactes que possible...............................................316 5.4.3 Comment MySQL utilise les index.......................................................................317 5.4.4 Index de colonnes................................................................................................318 5.4.5 Index sur plusieurs colonnes................................................................................319 5.4.6 Pourquoi tant de tables ouvertes ?......................................................................320 5.4.7 Quand MySQL ouvre et ferme les tables.............................................................320 5.4.8 Inconvnients de la cration d'un grand nombre de tables dans la mme

    base de donnes.....................................................................................................321 5.5 Optimisation du serveur MySQL...................................................................................321

    5.5.1 Rglage du systme, au moment de la compilation, et paramtres du dmarrage...............................................................................................................321

    5.5.2 Rglage des paramtres du serveur....................................................................322 5.5.3 Influences de la compilation et des liaisons sur la vitesse de MySQL.................324 5.5.4 Comment MySQL gre la mmoire......................................................................325 5.5.5 Comment MySQL utilise le DNS..........................................................................326

    Manuel MySQL 4.1.x Version Franaise

    vii

  • Sommaire 5 Optimisation de MySQL

    5.5.6 Syntaxe de SET...................................................................................................327 5.6 Problmes avec les disques.........................................................................................330

    5.6.1 Utiliser des liens symboliques..............................................................................330 5.6.1.1 Utiliser les liens symboliques pour les bases..............................................331 5.6.1.2 Utiliser des liens symboliques avec les tables............................................331

    6 Rfrence du langage MySQL..................................................................................................333 6.1 Structure du langage.....................................................................................................333

    6.1.1 Literals: Comment crire les chanes et les nombres..........................................333 6.1.1.1 Chanes.......................................................................................................333 6.1.1.2 Nombres......................................................................................................335 6.1.1.3 Valeurs hexadcimales...............................................................................335 6.1.1.4 Valeurs NULL..............................................................................................335

    6.1.2 Noms de bases, tables, index, colonnes et alias.................................................335 6.1.3 Sensibilit la casse pour les noms....................................................................336 6.1.4 Variables utilisateur..............................................................................................337 6.1.5 Variables systme................................................................................................338 6.1.6 Syntaxe des commentaires..................................................................................340 6.1.7 Estce que MySQL est sensible aux mots rservs ?.........................................341

    6.2 Types de colonnes........................................................................................................341 6.2.1 Types numriques................................................................................................345 6.2.2 Les types date et heure........................................................................................347

    6.2.2.1 An 2000 et les types date............................................................................348 6.2.2.2 Les types DATETIME , DATE , et TIMESTAMP.........................................348 6.2.2.3 Le type TIME...............................................................................................351 6.2.2.4 Le type YEAR..............................................................................................352

    6.2.3 Les types chanes................................................................................................353 6.2.3.1 Les types CHAR et VARCHAR...................................................................353 6.2.3.2 Les types BLOB et TEXT............................................................................354 6.2.3.3 Le type ENUM.............................................................................................354 6.2.3.4 Le type SET................................................................................................356

    6.2.4 Choisir le bon type de colonne.............................................................................357 6.2.5 Utilisation des types de donnes issues d'autres SGBDR...................................357 6.2.6 Capacits des colonnes.......................................................................................357

    6.3 Fonctions utiliser dans les clauses SELECT et WHERE...........................................358 6.3.1 Oprateurs et fonctions touttypes......................................................................359

    6.3.1.1 Parenthses................................................................................................359 6.3.1.2 Oprateurs de comparaison........................................................................359 6.3.1.3 Oprateurs logiques....................................................................................362 6.3.1.4 Les fonctions de contrle............................................................................363

    6.3.2 Fonctions de chanes de caractres....................................................................364 6.3.2.1 Oprateurs de comparaison pour les chanes de caractres.....................370 6.3.2.2 Sensibilit la casse...................................................................................371

    6.3.3 Fonctions numriques..........................................................................................372 6.3.3.1 Oprations arithmtiques............................................................................372 6.3.3.2 Fonctions mathmatiques...........................................................................372

    6.3.4 Fonctions de dates et d'heures............................................................................376 6.3.5 Fonctions de transtypage.....................................................................................382 6.3.6 Autres fonctions...................................................................................................383

    6.3.6.1 Fonctions sur les bits..................................................................................383 6.3.6.2 Fonctions diverses......................................................................................384

    Manuel MySQL 4.1.x Version Franaise

    viii

  • Sommaire 6 Rfrence du langage MySQL

    6.3.7 Fonctions avec la clause GROUP BY..................................................................389 6.4 Manipulation de donnes : SELECT , INSERT , UPDATE , DELETE..........................391

    6.4.1 Syntaxe de SELECT............................................................................................391 6.4.1.1 Syntaxe de JOIN.........................................................................................394 6.4.1.2 Syntaxe de UNION......................................................................................395

    6.4.2 Syntaxe de HANDLER.........................................................................................396 6.4.3 Syntaxe de INSERT.............................................................................................397

    6.4.3.1 Syntaxe de INSERT ... SELECT.................................................................398 6.4.4 Syntaxe de INSERT DELAYED...........................................................................399 6.4.5 Syntaxe de UPDATE............................................................................................400 6.4.6 Syntaxe de DELETE............................................................................................401 6.4.7 Syntaxe de TRUNCATE.......................................................................................402 6.4.8 Syntaxe de REPLACE.........................................................................................403 6.4.9 Syntaxe de LOAD DATA INFILE..........................................................................403 6.4.10 Syntaxe de DO...................................................................................................408

    6.5 Dfinition de donnes : CREATE , DROP , ALTER......................................................408 6.5.1 Syntaxe de CREATE DATABASE.......................................................................409 6.5.2 Syntaxe de DROP DATABASE............................................................................409 6.5.3 Syntaxe de CREATE TABLE...............................................................................409

    6.5.3.1 Modification automatique du type de colonnes...........................................415 6.5.4 Syntaxe de ALTER TABLE..................................................................................415 6.5.5 Syntaxe de RENAME TABLE..............................................................................418 6.5.6 Syntaxe de DROP TABLE...................................................................................419 6.5.7 Syntaxe de CREATE INDEX................................................................................419 6.5.8 Syntaxe de DROP INDEX....................................................................................420

    6.6 Commandes de bases de l'utilisateur de MySQL.........................................................420 6.6.1 Syntaxe de USE...................................................................................................420 6.6.2 Syntaxe de DESCRIBE (obtenir des informations sur les colonnes)...................420

    6.7 Commandes relatives aux verrous et aux transactions................................................421 6.7.1 Syntaxe de BEGIN/COMMIT/ROLLBACK...........................................................421 6.7.2 Syntaxe de LOCK TABLES/UNLOCK TABLES...................................................421 6.7.3 Syntaxe de SET TRANSACTION........................................................................423

    6.8 Recherche en Texteentier (Fulltext) dans MySQL....................................................424 6.8.1 Restrictions avec fulltext....................................................................................427 6.8.2 Paramtrage prcis de la recherche Fulltext de MySQL...................................427 6.8.3 A faire dans la recherche Fulltext......................................................................427

    6.9 Cache de requtes MySQL...........................................................................................428 6.9.1 Comment fonctionne le cache de requtes..........................................................428 6.9.2 Configuration du cache de requtes....................................................................429 6.9.3 Options relatives au cache de requtes dans un SELECT..................................430 6.9.4 Status du cache de requtes et maintenance......................................................430

    7 Types de tables MySQL............................................................................................................431 7.1 Tables MyISAM.............................................................................................................431

    7.1.1 Espace requis pour les clefs................................................................................434 7.1.2 Formats de table MyISAM....................................................................................434

    7.1.2.1 Caractristiques des tables statiques (taille fixe)......................................434 7.1.2.2 Caractristiques des tables format de ligne dynamiques.........................435 7.1.2.3 Caractristiques des tables compresses..................................................436

    7.1.3 Problmes avec les tables MyISAM.....................................................................436 7.1.3.1 Tables MyISAM corrompues.......................................................................436

    Manuel MySQL 4.1.x Version Franaise

    ix

  • Sommaire 7 Types de tables MySQL

    7.1.3.2 Clients is using or hasn't closed the table properly.....................................437 7.2 Tables assembles MERGE.........................................................................................438

    7.2.1 Problmes avec les tables MERGE.....................................................................440 7.3 Tables ISAM.................................................................................................................440 7.4 Tables HEAP................................................................................................................441 7.5 Tables InnoDB..............................................................................................................442

    7.5.1 Prsentation des tables InnoDB...........................................................................442 7.5.2 Options de dmarrage InnoDB............................................................................443 7.5.3 Crer des bases InnoDB......................................................................................446

    7.5.3.1 Si quelque chose se passe mal la cration de la base de donnes........447 7.5.4 Crer des tables InnoDB......................................................................................447 7.5.5 Ajouter et retirer des donnes et des logs InnoDB..............................................450 7.5.6 Sauver et restaurer une base InnoDB..................................................................450

    7.5.6.1 Points de contrle.......................................................................................451 7.5.7 Transfrer une base de donnes InnoDB vers une autre machine.....................452 7.5.8 Modle transactionnel de InnoDB........................................................................452

    7.5.8.1 Lecture cohrente.......................................................................................453 7.5.8.2 Verrous de lecture.......................................................................................454 7.5.8.3 Verrou de cl suivante : viter le problme des lignes fantmes................454 7.5.8.4 Les verrous poss par diffrentes requtes SQL avec InnoDB..................455 7.5.8.5 Dtection des blocages et annulation.........................................................456 7.5.8.6 Un exemple de lecture cohrente avec InnoDB..........................................456 7.5.8.7 Comment grer les blocages de verrous?..................................................457 7.5.8.8 Conseils sur l'amlioration des performances InnoDB................................457 7.5.8.9 Le moniteur InnoDB....................................................................................459

    7.5.9 Implmentation du multiversionnage.................................................................460 7.5.10 Structures de tables et d'index...........................................................................461

    7.5.10.1 Structure physique d'un index...................................................................461 7.5.10.2 Bufferisation des insertions.......................................................................462 7.5.10.3 Index hash adaptatifs................................................................................462 7.5.10.4 Structure physique d'une ligne..................................................................462

    7.5.11 Gestion de l'espace fichiers et des entres/sorties disque................................463 7.5.11.1 Accs disques...........................................................................................463 7.5.11.2 Gestion de l'espace fichier........................................................................464 7.5.11.3 Dfragmentation des tables......................................................................465

    7.5.12 Gestion des erreurs............................................................................................465 7.5.13 Restrictions sur les tables InnoDB.....................................................................465 7.5.14 Historique de l'volution InnoDB........................................................................466 7.5.15 Informations de contact InnoDB.........................................................................474

    7.6 Tables BDB ou BerkeleyDB..........................................................................................474 7.6.1 Vue d'ensemble des tables BDB..........................................................................474 7.6.2 Installation de BDB...............................................................................................475 7.6.3 Options de dmarrage BDB.................................................................................475 7.6.4 Caractristiques des tables BDB.........................................................................476 7.6.5 Ce que nous devons corriger dans BDB dans un futur proche :..........................477 7.6.6 Systmes d'exploitation supports par BDB........................................................477 7.6.7 Restrictions avec les tables BDB.........................................................................477 7.6.8 Erreurs pouvant survenir lors de l'utilisation des tables BDB...............................478

    Manuel MySQL 4.1.x Version Franaise

    x

  • Sommaire 8 Les interfaces pour MySQL......................................................................................................479

    8.1 API PHP pour MySQL...................................................................................................479 8.1.1 Problmes frquents avec MySQL et PHP..........................................................479

    8.2 API Perl pour MySQL....................................................................................................479 8.2.1 DBI avec DBD::mysql...........................................................................................479 8.2.2 L'interface DBI......................................................................................................480 8.2.3 Plus d'informations relatives DBI / DBD............................................................484

    8.3 Support ODBC avec MySQL........................................................................................485 8.3.1 Comment installer MyODBC................................................................................485 8.3.2 Comment remplir les diffrents champs dans le programme d'administrateur

    ODBC......................................................................................................................486 8.3.3 Paramtres de connexion de MyODBC...............................................................486 8.3.4 Comment reporter les problmes avec ODBC.....................................................487 8.3.5 Programmes qui fonctionnent avec MyODBC.....................................................488 8.3.6 Comment obtenir la valeur d'une colonne AUTO_INCREMENT avec ODBC.....491 8.3.7 Rapporter des problmes avec MyODBC............................................................492

    8.4 MySQL C API................................................................................................................492 8.4.1 Types de donnes de l'API C...............................................................................493 8.4.2 Vue d'ensemble des fonctions de l'API C............................................................495 8.4.3 Description des fonctions de l'API C....................................................................498

    8.4.3.1 mysql_affected_rows()................................................................................498 8.4.3.2 mysql_change_user()..................................................................................499 8.4.3.3 mysql_character_set_name()......................................................................500 8.4.3.4 mysql_close()..............................................................................................500 8.4.3.5 mysql_connect()..........................................................................................500 8.4.3.6 mysql_create_db()......................................................................................501 8.4.3.7 mysql_data_seek()......................................................................................501 8.4.3.8 mysql_debug()............................................................................................502 8.4.3.9 mysql_drop_db().........................................................................................502 8.4.3.10 mysql_dump_debug_info()........................................................................502 8.4.3.11 mysql_eof()...............................................................................................503 8.4.3.12 mysql_errno()............................................................................................504 8.4.3.13 mysql_error().............................................................................................504 8.4.3.14 mysql_escape_string()..............................................................................505 8.4.3.15 mysql_fetch_field()....................................................................................505 8.4.3.16 mysql_fetch_fields()..................................................................................506 8.4.3.17 mysql_fetch_field_direct().........................................................................506 8.4.3.18 mysql_fetch_lengths()...............................................................................507 8.4.3.19 mysql_fetch_row().....................................................................................507 8.4.3.20 mysql_field_count()...................................................................................508 8.4.3.21 mysql_field_seek()....................................................................................509 8.4.3.22 mysql_field_tell().......................................................................................509 8.4.3.23 mysql_free_result()...................................................................................509 8.4.3.24 mysql_get_client_info().............................................................................510 8.4.3.25 mysql_get_server_version()......................................................................510 8.4.3.26 mysql_get_host_info()...............................................................................510 8.4.3.27 mysql_get_proto_info().............................................................................511 8.4.3.28 mysql_get_server_info()............................................................................511 8.4.3.29 mysql_info()...............................................................................................511 8.4.3.30 mysql_init()................................................................................................512 8.4.3.31 mysql_insert_id().......................................................................................512 8.4.3.32 mysql_kill()................................................................................................512

    Manuel MySQL 4.1.x Version Franaise

    xi

  • Sommaire 8 Les interfaces pour MySQL

    8.4.3.33 mysql_list_dbs()........................................................................................513 8.4.3.34 mysql_list_fields()......................................................................................513 8.4.3.35 mysql_list_processes()..............................................................................513 8.4.3.36 mysql_list_tables()....................................................................................514 8.4.3.37 mysql_num_fields()...................................................................................514 8.4.3.38 mysql_num_rows()....................................................................................515 8.4.3.39 mysql_options().........................................................................................516 8.4.3.40 mysql_ping()..............................................................................................517 8.4.3.41 mysql_query()...........................................................................................517 8.4.3.42 mysql_real_connect()................................................................................518 8.4.3.43 mysql_real_escape_string()......................................................................519 8.4.3.44 mysql_real_query()...................................................................................519 8.4.3.45 mysql_reload()..........................................................................................520 8.4.3.46 mysql_row_seek().....................................................................................520 8.4.3.47 mysql_row_tell()........................................................................................521 8.4.3.48 mysql_select_db().....................................................................................521 8.4.3.49 mysql_shutdown().....................................................................................521 8.4.3.50 mysql_stat()...............................................................................................522 8.4.3.51 mysql_store_result()..................................................................................522 8.4.3.52 mysql_thread_id().....................................................................................523 8.4.3.53 mysql_use_result()....................................................................................523 8.4.3.54 mysql_commit().........................................................................................524 8.4.3.55 mysql_rollback()........................................................................................524 8.4.3.56 mysql_autocommit()..................................................................................524 8.4.3.57 mysql_more_results()................................................................................525 8.4.3.58 mysql_next_result()...................................................................................525

    8.4.4 Fonctions C de commandes prpares...............................................................525 8.4.5 C API Prepared Statements DataTypes..............................................................526 8.4.6 Prsentation des API C pour les commandes prpares....................................527 8.4.7 Descriptions des fonctions C pour les requtes prpares..................................528

    8.4.7.1 mysql_prepare()..........................................................................................528 8.4.7.2 mysql_param_count().................................................................................528 8.4.7.3 mysql_prepare_result()...............................................................................529 8.4.7.4 mysql_bind_param()...................................................................................529 8.4.7.5 mysql_execute()..........................................................................................530 8.4.7.6 mysql_stmt_affected_rows().......................................................................532 8.4.7.7 mysql_bind_result().....................................................................................532 8.4.7.8 mysql_stmt_store_result()...........................................................................533 8.4.7.9 mysql_fetch()...............................................................................................534 8.4.7.10 mysql_send_long_data()...........................................................................536 8.4.7.11 mysql_stmt_close()...................................................................................537 8.4.7.12 mysql_stmt_errno()...................................................................................537 8.4.7.13 mysql_stmt_error()....................................................................................538

    8.4.8 C API pour grer les requtes multiples..............................................................538 8.4.9 C API de gestions des DATE, TIME et TIMESTAMP..........................................539 8.4.10 Description des fonctions threades de C.........................................................539

    8.4.10.1 my_init()....................................................................................................539 8.4.10.2 mysql_thread_init()....................................................................................540 8.4.10.3 mysql_thread_end()..................................................................................540 8.4.10.4 mysql_thread_safe().................................................................................540

    8.4.11 Description des fonctions C du serveur embarqu............................................540

    Manuel MySQL 4.1.x Version Franaise

    xii

  • Sommaire 8 Les interfaces pour MySQL

    8.4.11.1 mysql_server_init()....................................................................................541 8.4.11.2 mysql_server_end()..................................................................................541

    8.4.12 Questions courantes sur la librairie C................................................................541 8.4.12.1 Pourquoi est ce qu'aprs mysql_query() ait indiqu un rsultat positif,

    mysql_store_result() retourne parfois NULL ?............................................541 8.4.12.2 Quels rsultats puisje obtenir d'une requte?.........................................542 8.4.12.3 Comment obtenir l'identifiant unique du dernier enregistrement insr

    ?..................................................................................................................542 8.4.12.4 Problmes lors de la liaison avec l'API C..................................................542

    8.4.13 Compiler les clients............................................................................................543 8.4.14 Comment faire un client MySQL thread...........................................................543 8.4.15 libmysqld, la librairie du serveur embarqu MySQL...........................................544

    8.4.15.1 Vue d'ensemble de la librairie du serveur embarqu MySQL...................544 8.4.15.2 Compiler des programmes avec libmysqld...............................................544 8.4.15.3 Restrictions lors de l'utilisation du serveur embarqu MySQL..................544 8.4.15.4 Utilisation de fichiers d'options avec le serveur embarqu.......................545 8.4.15.5 Choses faire pour le serveur embarqu (TODO)...................................545 8.4.15.6 Un exemple simple de serveur embarqu................................................545 8.4.15.7 Licence du serveur embarqu...................................................................547

    8.5 Interfaces MySQL pour C++.........................................................................................547 8.5.1 Borland C++.........................................................................................................547

    8.6 Connectivit Java/MySQL (JDBC)................................................................................547 8.7 Interface Python pour MySQL.......................................................................................548 8.8 Interface Tcl pour MySQL.............................................................................................548 8.9 Couche MySQL pour Eiffel...........................................................................................548

    9 Etendre MySQL..........................................................................................................................549 9.1 Rouages de MySQL......................................................................................................549

    9.1.1 Threads MySQL...................................................................................................549 9.1.2 Suite de test de MySQL.......................................................................................549

    9.1.2.1 Excuter la suite de tests MySQL...............................................................549 9.1.2.2 Amliorer la suite de tests MySQL..............................................................550 9.1.2.3 Rapporter des bugs dans la suite de tests MySQL.....................................550

    9.2 Ajouter des fonctions MySQL....................................................................................551 9.2.1 Syntaxe de CREATE FUNCTION/DROP FUNCTION.........................................551 9.2.2 Ajouter une nouvelle fonction dfinie par l'utilisateur (UDF)................................551

    9.2.2.1 Fonctions utiliateur : appeler des fonctions simples....................................552 9.2.2.2 Appeler des fonctions utilisateurs pour les groupements............................553 9.2.2.3 Traitement des arguments..........................................................................554 9.2.2.4 Valeurs de retour et gestion d'erreurs.........................................................554 9.2.2.5 Compiler et installer des fonctions utilisateurs............................................555

    9.2.3 Ajouter de nouvelles fonctions natives.................................................................556 9.3 Ajouter une nouvelle procdure MySQL....................................................................556

    9.3.1 La procdure Analyse..........................................................................................557 9.3.2 Ecrire une procdure............................................................................................557

    10 Problmes et erreurs communes ...........................................................................................558 10.1 Comment dterminer ce qui pose problme...............................................................558 10.2 Erreurs communes rencontres avec MySQL............................................................558

    10.2.1 Erreur Access denied.........................................................................................559 10.2.2 Erreur MySQL server has gone away................................................................559

    Manuel MySQL 4.1.x Version Franaise

    xiii

  • Sommaire 10 Problmes et erreurs communes

    10.2.3 Erreur Can't connect to [local] MySQL server....................................................559 10.2.4 Host '...' is blocked Error....................................................................................560 10.2.5 Erreur Too many connections............................................................................561 10.2.6 Erreur Some nontransactional changed tables couldn't be rolled back...........561 10.2.7 Erreur Out of memory........................................................................................561 10.2.8 Erreur Packet too large......................................................................................561 10.2.9 Erreurs de communication / Connexion annule...............................................562 10.2.10 Erreur The table is full......................................................................................563 10.2.11 Erreur Can't create/write to file.........................................................................563 10.2.12 Erreur du client Commands out of sync...........................................................563 10.2.13 Erreur Ignoring user.........................................................................................563 10.2.14 Erreur Table 'xxx' doesn't exist........................................................................564 10.2.15 Erreur Can't initialize character set xxx............................................................564 10.2.16 Fichier non trouv............................................................................................564

    10.3 Notes relatives l'installation......................................................................................565 10.3.1 Problmes lors de la liaison avec la librairie du client MySQL...........................565 10.3.2 Comment excuter MySQL comme un utilisateur normal..................................566 10.3.3 Problmes avec les permissions sur fichiers.....................................................566

    10.4 Notes relatives l'administration................................................................................566 10.4.1 Que faire si MySQL crashe constamment ?......................................................567 10.4.2 Comment rinitialiser un mot de passe Root oubli...........................................568 10.4.3 Comment MySQL gre un disque plein.............................................................568 10.4.4 O MySQL stocke les fichiers temporaires ?.....................................................568 10.4.5 Comment protger ou changer le fichier socket /tmp/mysql.sock......................569 10.4.6 Problmes de fuseaux horaires.........................................................................569

    10.5 Problmes relatifs aux requtes.................................................................................569 10.5.1 Sensibilit la casse dans les recherches........................................................570 10.5.2 Problmes avec l'utilisation des colonnes DATE...............................................570 10.5.3 Problmes avec les valeurs NULL.....................................................................571 10.5.4 Problmes avec les alias...................................................................................571 10.5.5 Effacer des lignes de tables relies...................................................................572 10.5.6 Rsoudre les problmes des lignes non retournes..........................................572 10.5.7 Problmes de comparaisons avec nombres virgule flottante..........................572

    10.6 Questions relatives aux dfinitions de tables..............................................................574 10.6.1 Problmes avec ALTER TABLE .......................................................................574 10.6.2 Comment changer l'ordre des colonnes dans une table....................................574 10.6.3 Problmes avec les tables temporaires.............................................................574

    11 Contributions ...........................................................................................................................576

    12 Crdits ......................................................................................................................................578 12.1 Dveloppeurs chez MySQL AB..................................................................................578 12.2 Contributeurs MySQL..............................................................................................579 12.3 Supporters de MySQL................................................................................................581

    13 Historique des changements MySQL....................................................................................583 13.1 Changes in release 5.0.0 (Development)...................................................................583 13.2 Changes in release 4.1.x (Alpha)................................................................................583

    13.2.1 Changes in release 4.1.0...................................................................................583 13.3 Changements dans la publication 4.0.x (Beta)...........................................................584

    13.3.1 Changes in release 4.0.13 (not released yet)....................................................584

    Manuel MySQL 4.1.x Version Franaise

    xiv

  • Sommaire 13 Historique des changements MySQL

    13.3.2 Changes in release 4.0.12 (15 Mar 2003: Production)......................................585 13.3.3 Changes in release 4.0.11 (20 Feb 2003)..........................................................585 13.3.4 Changes in release 4.0.10 (29 Jan 2003)..........................................................586 13.3.5 Changes in release 4.0.9 (09 Jan 2003)............................................................586 13.3.6 Changes in release 4.0.8 (07 Jan 2003)............................................................587 13.3.7 Changes in release 4.0.7 (20 Dec 2002)...........................................................587 13.3.8 Changes in release 4.0.6 (14 Dec 2002: Gamma).............................................587 13.3.9 Changes in release 4.0.5 (13 Nov 2002)...........................................................588 13.3.10 Changes in release 4.0.4 (29 Sep 2002).........................................................588 13.3.11 Changes in release 4.0.3 (26 Aug 2002: Beta)................................................589 13.3.12 Changes in release 4.0.2 (01 Jul 2002)...........................................................590 13.3.13 Changes in release 4.0.1 (23 Dec 2001).........................................................591 13.3.14 Changes in release 4.0.0 (Oct 2001: Alpha)....................................................591

    13.4 Changes in release 3.23.x (Recent; still supported)...................................................592 13.4.1 Changes in release 3.23.57 (not released yet)..................................................592 13.4.2 Changes in release 3.23.56 (13 Mar 2003)........................................................592 13.4.3 Changes in release 3.23.55 (23 Jan 2003)........................................................593 13.4.4 Changes in release 3.23.54 (05 Dec 2002).......................................................593 13.4.5 Changes in release 3.23.53 (09 Oct 2002)........................................................593 13.4.6 Changes in release 3.23.52 (14 Aug 2002).......................................................594 13.4.7 Changes in release 3.23.51 (31 May 2002).......................................................594 13.4.8 Changes in release 3.23.50 (21 Apr 2002)........................................................594 13.4.9 Changes in release 3.23.49...............................................................................595 13.4.10 Changes in release 3.23.48 (07 Feb 2002)......................................................595 13.4.11 Changes in release 3.23.47 (27 Dec 2001).....................................................595 13.4.12 Changes in release 3.23.46 (29 Nov 2001).....................................................595 13.4.13 Changes in release 3.23.45 (22 Nov 2001).....................................................595 13.4.14 Changes in release 3.23.44 (31 Oct 2001)......................................................596 13.4.15 Changes in release 3.23.43 (04 Oct 2001)......................................................596 13.4.16 Changes in release 3.23.42 (08 Sep 2001).....................................................596 13.4.17 Changes in release 3.23.41 (11 Aug 2001).....................................................596 13.4.18 Changes in release 3.23.40.............................................................................597 13.4.19 Changes in release 3.23.39 (12 Jun 2001)......................................................597 13.4.20 Changes in release 3.23.38 (09 May 2001).....................................................597 13.4.21 Changes in release 3.23.37 (17 Apr 2001)......................................................597 13.4.22 Changes in release 3.23.36 (27 Mar 2001)......................................................598 13.4.23 Changes in release 3.23.35 (15 Mar 2001)......................................................598 13.4.24 Changes in release 3.23.34a...........................................................................598 13.4.25 Changes in release 3.23.34 (10 Mar 2001)......................................................598 13.4.26 Changes in release 3.23.33 (09 Feb 2001)......................................................599 13.4.27 Changes in release 3.23.32 (22 Jan 2001: Stable)..........................................599 13.4.28 Changes in release 3.23.31 (17 Jan 2001)......................................................599 13.4.29 Changes in release 3.23.30 (04 Jan 2001)......................................................600 13.4.30 Changes in release 3.23.29 (16 Dec 2000).....................................................600 13.4.31 Changes in release 3.23.28 (22 Nov 2000: Gamma).......................................600 13.4.32 Changes in release 3.23.27 (24 Oct 2000)......................................................601 13.4.33 Changes in release 3.23.26 (18 Oct 2000)......................................................601 13.4.34 Changes in release 3.23.25 (29 Sep 2000).....................................................602 13.4.35 Changes in release 3.23.24 (08 Sep 2000).....................................................602 13.4.36 Changes in release 3.23.23 (01 Sep 2000).....................................................602 13.4.37 Changes in release 3.23.22 (31 Jul 2000).......................................................603

    Manuel MySQL 4.1.x Version Franaise

    xv

  • Sommaire 13 Historique des changements MySQL

    13.4.38 Changes in release 3.23.21.............................................................................603 13.4.39 Changes in release 3.23.20.............................................................................603 13.4.40 Changes in release 3.23.19.............................................................................603 13.4.41 Changes in release 3.23.18.............................................................................603 13.4.42 Changes in release 3.23.17.............................................................................604 13.4.43 Changes in release 3.23.16.............................................................................604 13.4.44 Changes in release 3.23.15 (May 2000: Beta).................................................604 13.4.45 Changes in release 3.23.14.............................................................................604 13.4.46 Changes in release 3.23.13.............................................................................605 13.4.47 Changes in release 3.23.12 (07 Mar 2000)......................................................605 13.4.48 Changes in release 3.23.11.............................................................................605 13.4.49 Changes in release 3.23.10.............................................................................605 13.4.50 Changes in release 3.23.9...............................................................................605 13.4.51 Changes in release 3.23.8 (02 Jan 2000)........................................................606 13.4.52 Changes in release 3.23.7 (10 Dec 1999).......................................................606 13.4.53 Changes in release 3.23.6...............................................................................606 13.4.54 Changes in release 3.23.5 (20 Oct 1999)........................................................607 13.4.55 Changes in release 3.23.4 (28 Sep 1999).......................................................607 13.4.56 Changes in release 3.23.3...............................................................................607 13.4.57 Changes in release 3.23.2 (09 Aug 1999).......................................................607 13.4.58 Changes in release 3.23.1...............................................................................608 13.4.59 Changes in release 3.23.0 (05 Aug 1999: Alpha)............................................608

    13.5 Changes in release 3.22.x (Older; still supported)......................................................608 13.5.1 Changes in release 3.22.35...............................................................................609 13.5.2 Changes in release 3.22.34...............................................................................609 13.5.3 Changes in release 3.22.33...............................................................................609 13.5.4 Changes in release 3.22.32 (14 Feb 2000)........................................................609 13.5.5 Changes in release 3.22.31...............................................................................609 13.5.6 Changes in release 3.22.30...............................................................................609 13.5.7 Changes in release 3.22.29 (02 Jan 2000)........................................................609 13.5.8 Changes in release 3.22.28 (20 Oct 1999)........................................................609 13.5.9 Changes in release 3.22.27...............................................................................609 13.5.10 Changes in release 3.22.26 (16 Sep 1999).....................................................610 13.5.11 Changes in release 3.22.25.............................................................................610 13.5.12 Changes in release 3.22.24 (05 Jul 1999).......................................................610 13.5.13 Changes in release 3.22.23 (08 Jun 1999)..............................