mysql reference manual - ubc ecebrucew/ebook/mysqlmanual.pdf · iii 2 installing mysql..... 59 2.1...

1319
MySQL Reference Manual Copyright c 1997-2004 MySQL AB

Upload: others

Post on 25-Jun-2020

9 views

Category:

Documents


0 download

TRANSCRIPT

  • MySQL Reference Manual

    Copyright c© 1997-2004 MySQL AB

  • i

    Table of Contents

    1 General Information . . . . . . . . . . . . . . . . . . . . . . . 11.1 About This Manual . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2

    1.1.1 Conventions Used in This Manual . . . . . . . . . . . . . . . . 21.2 Overview of the MySQL Database Management System . . . . 4

    1.2.1 History of MySQL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51.2.2 The Main Features of MySQL . . . . . . . . . . . . . . . . . . . 61.2.3 MySQL Stability . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81.2.4 How Big MySQL Tables Can Be . . . . . . . . . . . . . . . . . 91.2.5 Year 2000 Compliance . . . . . . . . . . . . . . . . . . . . . . . . . 10

    1.3 Overview of MySQL AB . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 121.3.1 The Business Model and Services of MySQL AB . . 13

    1.3.1.1 Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 131.3.1.2 Training and Certification . . . . . . . . . . . . . 131.3.1.3 Consulting . . . . . . . . . . . . . . . . . . . . . . . . . . . 141.3.1.4 Commercial Licenses . . . . . . . . . . . . . . . . . . 141.3.1.5 Partnering . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14

    1.3.2 Contact Information . . . . . . . . . . . . . . . . . . . . . . . . . . . 151.4 MySQL Support and Licensing . . . . . . . . . . . . . . . . . . . . . . . . . . 16

    1.4.1 Support Offered by MySQL AB. . . . . . . . . . . . . . . . . 161.4.2 Copyrights and Licenses Used by MySQL. . . . . . . . 171.4.3 MySQL Licenses . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17

    1.4.3.1 Using the MySQL Software Under aCommercial License . . . . . . . . . . . . . . . . . . . . . . . 18

    1.4.3.2 Using the MySQL Software for Free UnderGPL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18

    1.4.4 MySQL AB Logos and Trademarks . . . . . . . . . . . . . 191.4.4.1 The Original MySQL Logo. . . . . . . . . . . . . 201.4.4.2 MySQL Logos That May Be Used Without

    Written Permission . . . . . . . . . . . . . . . . . . . . . . . 201.4.4.3 When You Need Written Permission to Use

    MySQL Logos . . . . . . . . . . . . . . . . . . . . . . . . . . . . 201.4.4.4 MySQL AB Partnership Logos . . . . . . . . . 211.4.4.5 Using the Word MySQL in Printed Text or

    Presentations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 211.4.4.6 Using the Word MySQL in Company and

    Product Names . . . . . . . . . . . . . . . . . . . . . . . . . . . 211.5 MySQL Development Roadmap . . . . . . . . . . . . . . . . . . . . . . . . . 21

    1.5.1 MySQL 4.0 in a Nutshell . . . . . . . . . . . . . . . . . . . . . . . 221.5.1.1 Features Available in MySQL 4.0 . . . . . . . 221.5.1.2 The Embedded MySQL Server . . . . . . . . . 23

    1.5.2 MySQL 4.1 in a Nutshell . . . . . . . . . . . . . . . . . . . . . . . 241.5.2.1 Features Available in MySQL 4.1 . . . . . . . 241.5.2.2 Stepwise Rollout . . . . . . . . . . . . . . . . . . . . . . 25

  • ii

    1.5.2.3 Ready for Immediate Development Use. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25

    1.5.3 MySQL 5.0: The Next Development Release . . . . . 261.6 MySQL and the Future (the TODO) . . . . . . . . . . . . . . . . . . . . 26

    1.6.1 New Features Planned for 4.1 . . . . . . . . . . . . . . . . . . . 261.6.2 New Features Planned for 5.0 . . . . . . . . . . . . . . . . . . . 261.6.3 New Features Planned for 5.1 . . . . . . . . . . . . . . . . . . . 271.6.4 New Features Planned for the Near Future . . . . . . 281.6.5 New Features Planned for the Mid-Term Future . . 301.6.6 New Features We Don’t Plan to Implement . . . . . . 31

    1.7 MySQL Information Sources . . . . . . . . . . . . . . . . . . . . . . . . . . . . 321.7.1 MySQL Mailing Lists . . . . . . . . . . . . . . . . . . . . . . . . . . 32

    1.7.1.1 The MySQL Mailing Lists . . . . . . . . . . . . . 321.7.1.2 Asking Questions or Reporting Bugs. . . . 341.7.1.3 How to Report Bugs or Problems . . . . . . 351.7.1.4 Guidelines for Answering Questions on the

    Mailing List . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 391.7.2 MySQL Community Support on IRC (Internet Relay

    Chat) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 401.8 MySQL Standards Compliance . . . . . . . . . . . . . . . . . . . . . . . . . . 40

    1.8.1 What Standards MySQL Follows . . . . . . . . . . . . . . . 411.8.2 Selecting SQL Modes . . . . . . . . . . . . . . . . . . . . . . . . . . 411.8.3 Running MySQL in ANSI Mode . . . . . . . . . . . . . . . . 411.8.4 MySQL Extensions to Standard SQL . . . . . . . . . . . . 421.8.5 MySQL Differences from Standard SQL . . . . . . . . . 45

    1.8.5.1 Subqueries . . . . . . . . . . . . . . . . . . . . . . . . . . . 451.8.5.2 SELECT INTO TABLE . . . . . . . . . . . . . . . . . . . 451.8.5.3 Transactions and Atomic Operations . . . 451.8.5.4 Stored Procedures and Triggers . . . . . . . . 481.8.5.5 Foreign Keys . . . . . . . . . . . . . . . . . . . . . . . . . 481.8.5.6 Views . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 501.8.5.7 ‘--’ as the Start of a Comment . . . . . . . . . 50

    1.8.6 How MySQL Deals with Constraints . . . . . . . . . . . . 511.8.6.1 Constraint PRIMARY KEY / UNIQUE . . . . . . 511.8.6.2 Constraint NOT NULL and DEFAULT Values

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 521.8.6.3 Constraint ENUM and SET . . . . . . . . . . . . . . 52

    1.8.7 Known Errors and Design Deficiencies in MySQL. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53

    1.8.7.1 Errors in 3.23 Fixed in a Later MySQLVersion. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53

    1.8.7.2 Errors in 4.0 Fixed in a Later MySQLVersion. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53

    1.8.7.3 Open Bugs and Design Deficiencies inMySQL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53

  • iii

    2 Installing MySQL . . . . . . . . . . . . . . . . . . . . . . . . . 592.1 General Installation Issues . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59

    2.1.1 Operating Systems Supported by MySQL . . . . . . . 602.1.2 Choosing Which MySQL Distribution to Install . . 61

    2.1.2.1 Choosing Which Version of MySQL toInstall. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62

    2.1.2.2 Choosing a Distribution Format . . . . . . . . 642.1.2.3 How and When Updates Are Released . . 652.1.2.4 Release Philosophy—No Known Bugs in

    Releases . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 652.1.2.5 MySQL Binaries Compiled by MySQL AB

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 672.1.3 How to Get MySQL . . . . . . . . . . . . . . . . . . . . . . . . . . . 732.1.4 Verifying Package Integrity Using MD5 Checksums

    or GnuPG . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 732.1.4.1 Verifying the MD5 Checksum . . . . . . . . . . 732.1.4.2 Signature Checking Using GnuPG . . . . . . . 742.1.4.3 Signature Checking Using RPM. . . . . . . . . . 75

    2.1.5 Installation Layouts . . . . . . . . . . . . . . . . . . . . . . . . . . . . 762.2 Standard MySQL Installation Using a Binary Distribution

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 772.2.1 Installing MySQL on Windows . . . . . . . . . . . . . . . . . 78

    2.2.1.1 Windows System Requirements . . . . . . . . 782.2.1.2 Installing a Windows Binary Distribution

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 792.2.1.3 Preparing the Windows MySQL

    Environment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 792.2.1.4 Selecting a Windows Server . . . . . . . . . . . . 812.2.1.5 Starting the Server for the First Time . . 812.2.1.6 Starting MySQL from the Windows

    Command Line . . . . . . . . . . . . . . . . . . . . . . . . . . . 832.2.1.7 Starting MySQL as a Windows Service . . 832.2.1.8 Troubleshooting a MySQL Installation

    Under Windows . . . . . . . . . . . . . . . . . . . . . . . . . . 852.2.1.9 Running MySQL Client Programs on

    Windows . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 862.2.1.10 MySQL on Windows Compared to

    MySQL on Unix . . . . . . . . . . . . . . . . . . . . . . . . . . 872.2.2 Installing MySQL on Linux . . . . . . . . . . . . . . . . . . . . . 902.2.3 Installing MySQL on Mac OS X . . . . . . . . . . . . . . . . 922.2.4 Installing MySQL on NetWare . . . . . . . . . . . . . . . . . . 952.2.5 Installing MySQL on Other Unix-Like Systems. . . 96

    2.3 MySQL Installation Using a Source Distribution . . . . . . . . . . 992.3.1 Source Installation Overview . . . . . . . . . . . . . . . . . . 1002.3.2 Typical configure Options . . . . . . . . . . . . . . . . . . . 1032.3.3 Installing from the Development Source Tree . . . 1062.3.4 Dealing with Problems Compiling MySQL . . . . . . 1082.3.5 MIT-pthreads Notes . . . . . . . . . . . . . . . . . . . . . . . . . . 112

  • iv

    2.3.6 Installing MySQL from Source on Windows. . . . . 1132.3.6.1 Building MySQL Using VC++ . . . . . . . . . 1142.3.6.2 Creating a Windows Source Package from

    the Latest Development Source . . . . . . . . . . . 1152.3.7 Compiling MySQL Clients on Windows . . . . . . . . 116

    2.4 Post-Installation Setup and Testing . . . . . . . . . . . . . . . . . . . . . 1172.4.1 Windows Post-Installation Procedures . . . . . . . . . . 1172.4.2 Unix Post-Installation Procedures . . . . . . . . . . . . . . 118

    2.4.2.1 Problems Running mysql_install_db. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 122

    2.4.2.2 Starting and Stopping MySQLAutomatically . . . . . . . . . . . . . . . . . . . . . . . . . . . 124

    2.4.2.3 Starting and Troubleshooting the MySQLServer. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126

    2.4.3 Securing the Initial MySQL Accounts . . . . . . . . . . 1292.5 Upgrading/Downgrading MySQL . . . . . . . . . . . . . . . . . . . . . . . 132

    2.5.1 Upgrading from Version 4.1 to 5.0 . . . . . . . . . . . . . 1332.5.2 Upgrading from Version 4.0 to 4.1 . . . . . . . . . . . . . 1332.5.3 Upgrading from Version 3.23 to 4.0 . . . . . . . . . . . . 1382.5.4 Upgrading from Version 3.22 to 3.23 . . . . . . . . . . . 1412.5.5 Upgrading from Version 3.21 to 3.22 . . . . . . . . . . . 1432.5.6 Upgrading from Version 3.20 to 3.21 . . . . . . . . . . . 1432.5.7 Upgrading MySQL Under Windows . . . . . . . . . . . . 1442.5.8 Upgrading the Grant Tables . . . . . . . . . . . . . . . . . . . 1452.5.9 Copying MySQL Databases to Another Machine

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1462.6 Operating System-Specific Notes . . . . . . . . . . . . . . . . . . . . . . . 147

    2.6.1 Linux Notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1472.6.1.1 Linux Operating System Notes . . . . . . . . 1472.6.1.2 Linux Binary Distribution Notes . . . . . . 1482.6.1.3 Linux Source Distribution Notes . . . . . . 1492.6.1.4 Linux Post-Installation Notes . . . . . . . . . 1502.6.1.5 Linux x86 Notes . . . . . . . . . . . . . . . . . . . . . 1522.6.1.6 Linux SPARC Notes . . . . . . . . . . . . . . . . . 1532.6.1.7 Linux Alpha Notes . . . . . . . . . . . . . . . . . . . 1542.6.1.8 Linux PowerPC Notes . . . . . . . . . . . . . . . . 1542.6.1.9 Linux MIPS Notes . . . . . . . . . . . . . . . . . . . 1542.6.1.10 Linux IA-64 Notes . . . . . . . . . . . . . . . . . . 155

    2.6.2 Mac OS X Notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1552.6.2.1 Mac OS X 10.x (Darwin) . . . . . . . . . . . . . 1552.6.2.2 Mac OS X Server 1.2 (Rhapsody) . . . . . 155

    2.6.3 Solaris Notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1562.6.3.1 Solaris 2.7/2.8 Notes . . . . . . . . . . . . . . . . . 1582.6.3.2 Solaris x86 Notes . . . . . . . . . . . . . . . . . . . . 159

    2.6.4 BSD Notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1592.6.4.1 FreeBSD Notes . . . . . . . . . . . . . . . . . . . . . . 1592.6.4.2 NetBSD Notes . . . . . . . . . . . . . . . . . . . . . . . 1612.6.4.3 OpenBSD 2.5 Notes . . . . . . . . . . . . . . . . . . 161

  • v

    2.6.4.4 OpenBSD 2.8 Notes . . . . . . . . . . . . . . . . . . 1612.6.4.5 BSD/OS Version 2.x Notes . . . . . . . . . . . 1612.6.4.6 BSD/OS Version 3.x Notes . . . . . . . . . . . 1622.6.4.7 BSD/OS Version 4.x Notes . . . . . . . . . . . 162

    2.6.5 Other Unix Notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1632.6.5.1 HP-UX Version 10.20 Notes. . . . . . . . . . . 1632.6.5.2 HP-UX Version 11.x Notes. . . . . . . . . . . . 1632.6.5.3 IBM-AIX notes . . . . . . . . . . . . . . . . . . . . . . 1652.6.5.4 SunOS 4 Notes . . . . . . . . . . . . . . . . . . . . . . 1662.6.5.5 Alpha-DEC-UNIX Notes (Tru64) . . . . . . 1672.6.5.6 Alpha-DEC-OSF/1 Notes . . . . . . . . . . . . . 1682.6.5.7 SGI Irix Notes . . . . . . . . . . . . . . . . . . . . . . . 1692.6.5.8 SCO Notes . . . . . . . . . . . . . . . . . . . . . . . . . . 1702.6.5.9 SCO UnixWare Version 7.1.x Notes. . . . 172

    2.6.6 OS/2 Notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1722.6.7 BeOS Notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 173

    2.7 Perl Installation Notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1732.7.1 Installing Perl on Unix . . . . . . . . . . . . . . . . . . . . . . . . 1732.7.2 Installing ActiveState Perl on Windows . . . . . . . . 1742.7.3 Problems Using the Perl DBI/DBD Interface . . . . . 175

    3 MySQL Tutorial . . . . . . . . . . . . . . . . . . . . . . . . . 1783.1 Connecting to and Disconnecting from the Server . . . . . . . . 1783.2 Entering Queries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1793.3 Creating and Using a Database. . . . . . . . . . . . . . . . . . . . . . . . . 182

    3.3.1 Creating and Selecting a Database . . . . . . . . . . . . . 1833.3.2 Creating a Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1843.3.3 Loading Data into a Table . . . . . . . . . . . . . . . . . . . . 1853.3.4 Retrieving Information from a Table . . . . . . . . . . . 186

    3.3.4.1 Selecting All Data . . . . . . . . . . . . . . . . . . . 1873.3.4.2 Selecting Particular Rows . . . . . . . . . . . . . 1873.3.4.3 Selecting Particular Columns . . . . . . . . . 1893.3.4.4 Sorting Rows . . . . . . . . . . . . . . . . . . . . . . . . 1903.3.4.5 Date Calculations . . . . . . . . . . . . . . . . . . . . 1913.3.4.6 Working with NULL Values . . . . . . . . . . . . 1943.3.4.7 Pattern Matching . . . . . . . . . . . . . . . . . . . . 1953.3.4.8 Counting Rows . . . . . . . . . . . . . . . . . . . . . . 1983.3.4.9 Using More Than one Table . . . . . . . . . . 200

    3.4 Getting Information About Databases and Tables . . . . . . . 2013.5 Using mysql in Batch Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2023.6 Examples of Common Queries . . . . . . . . . . . . . . . . . . . . . . . . . . 204

    3.6.1 The Maximum Value for a Column . . . . . . . . . . . . 2053.6.2 The Row Holding the Maximum of a Certain

    Column . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2053.6.3 Maximum of Column per Group . . . . . . . . . . . . . . . 2063.6.4 The Rows Holding the Group-wise Maximum of a

    Certain Field . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2063.6.5 Using User Variables . . . . . . . . . . . . . . . . . . . . . . . . . . 207

  • vi

    3.6.6 Using Foreign Keys . . . . . . . . . . . . . . . . . . . . . . . . . . . 2073.6.7 Searching on Two Keys . . . . . . . . . . . . . . . . . . . . . . . 2093.6.8 Calculating Visits Per Day . . . . . . . . . . . . . . . . . . . . 2103.6.9 Using AUTO_INCREMENT. . . . . . . . . . . . . . . . . . . . . . . . 210

    3.7 Queries from the Twin Project . . . . . . . . . . . . . . . . . . . . . . . . . 2123.7.1 Find All Non-distributed Twins. . . . . . . . . . . . . . . . 2123.7.2 Show a Table of Twin Pair Status . . . . . . . . . . . . . 215

    3.8 Using MySQL with Apache . . . . . . . . . . . . . . . . . . . . . . . . . . . . 215

    4 Using MySQL Programs . . . . . . . . . . . . . . . . . 2164.1 Overview of MySQL Programs . . . . . . . . . . . . . . . . . . . . . . . . . 2164.2 Invoking MySQL Programs . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2164.3 Specifying Program Options . . . . . . . . . . . . . . . . . . . . . . . . . . . 217

    4.3.1 Using Options on the Command Line . . . . . . . . . . 2184.3.2 Using Option Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2194.3.3 Using Environment Variables to Specify Options

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2234.3.4 Using Options to Set Program Variables . . . . . . . . 223

    5 Database Administration . . . . . . . . . . . . . . . . . 2255.1 The MySQL Server and Server Startup Scripts . . . . . . . . . . 225

    5.1.1 Overview of the Server-Side Scripts and Utilities. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 225

    5.1.2 The mysqld-max Extended MySQL Server . . . . . . 2265.1.3 The mysqld_safe Server Startup Script . . . . . . . . 2285.1.4 The mysql.server Server Startup Script . . . . . . . 2315.1.5 The mysqld_multi Program for Managing Multiple

    MySQL Servers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2315.2 Configuring the MySQL Server . . . . . . . . . . . . . . . . . . . . . . . . . 235

    5.2.1 mysqld Command-Line Options . . . . . . . . . . . . . . . 2355.2.2 The Server SQL Mode . . . . . . . . . . . . . . . . . . . . . . . . 2455.2.3 Server System Variables . . . . . . . . . . . . . . . . . . . . . . . 247

    5.2.3.1 Dynamic System Variables . . . . . . . . . . . . 2685.2.4 Server Status Variables . . . . . . . . . . . . . . . . . . . . . . . 271

    5.3 General Security Issues . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2775.3.1 General Security Guidelines . . . . . . . . . . . . . . . . . . . 2775.3.2 Making MySQL Secure Against Attackers . . . . . . 2805.3.3 Startup Options for mysqld Concerning Security

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2825.3.4 Security Issues with LOAD DATA LOCAL . . . . . . . . . . 283

    5.4 The MySQL Access Privilege System . . . . . . . . . . . . . . . . . . . 2845.4.1 What the Privilege System Does . . . . . . . . . . . . . . . 2845.4.2 How the Privilege System Works . . . . . . . . . . . . . . . 2845.4.3 Privileges Provided by MySQL . . . . . . . . . . . . . . . . 2885.4.4 Connecting to the MySQL Server . . . . . . . . . . . . . . 2915.4.5 Access Control, Stage 1: Connection Verification

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2925.4.6 Access Control, Stage 2: Request Verification . . . 295

  • vii

    5.4.7 When Privilege Changes Take Effect . . . . . . . . . . . 2985.4.8 Causes of Access denied Errors . . . . . . . . . . . . . . . 2985.4.9 Password Hashing in MySQL 4.1 . . . . . . . . . . . . . . 303

    5.4.9.1 Implications of Password Hashing Changesfor Application Programs . . . . . . . . . . . . . . . . . 308

    5.4.9.2 Password Hashing in MySQL 4.1.0 . . . . 3085.5 MySQL User Account Management . . . . . . . . . . . . . . . . . . . . . 308

    5.5.1 MySQL Usernames and Passwords . . . . . . . . . . . . . 3085.5.2 Adding New User Accounts to MySQL . . . . . . . . . 3105.5.3 Removing User Accounts from MySQL . . . . . . . . . 3135.5.4 Limiting Account Resources . . . . . . . . . . . . . . . . . . . 3135.5.5 Assigning Account Passwords . . . . . . . . . . . . . . . . . . 3155.5.6 Keeping Your Password Secure . . . . . . . . . . . . . . . . 3165.5.7 Using Secure Connections . . . . . . . . . . . . . . . . . . . . . 317

    5.5.7.1 Basic SSL Concepts . . . . . . . . . . . . . . . . . . 3175.5.7.2 Requirements . . . . . . . . . . . . . . . . . . . . . . . . 3185.5.7.3 Setting Up SSL Certificates for MySQL

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3195.5.7.4 SSL GRANT Options . . . . . . . . . . . . . . . . . . 3235.5.7.5 SSL Command-Line Options . . . . . . . . . . 3245.5.7.6 Connecting to MySQL Remotely from

    Windows with SSH . . . . . . . . . . . . . . . . . . . . . . 3255.6 Disaster Prevention and Recovery . . . . . . . . . . . . . . . . . . . . . . 326

    5.6.1 Database Backups . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3265.6.2 Table Maintenance and Crash Recovery . . . . . . . . 327

    5.6.2.1 myisamchk Invocation Syntax . . . . . . . . . 3285.6.2.2 General Options for myisamchk . . . . . . . 3295.6.2.3 Check Options for myisamchk . . . . . . . . . 3315.6.2.4 Repair Options for myisamchk . . . . . . . . 3325.6.2.5 Other Options for myisamchk . . . . . . . . . 3335.6.2.6 myisamchk Memory Usage . . . . . . . . . . . . 3345.6.2.7 Using myisamchk for Crash Recovery . . 3355.6.2.8 How to Check MyISAM Tables for Errors

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3365.6.2.9 How to Repair Tables . . . . . . . . . . . . . . . . 3365.6.2.10 Table Optimization . . . . . . . . . . . . . . . . . 339

    5.6.3 Setting Up a Table Maintenance Schedule . . . . . . 3395.6.4 Getting Information About a Table . . . . . . . . . . . . 340

    5.7 MySQL Localization and International Usage . . . . . . . . . . . 3465.7.1 The Character Set Used for Data and Sorting . . . 346

    5.7.1.1 Using the German Character Set . . . . . . 3475.7.2 Setting the Error Message Language . . . . . . . . . . . 3475.7.3 Adding a New Character Set . . . . . . . . . . . . . . . . . . 3485.7.4 The Character Definition Arrays . . . . . . . . . . . . . . . 3495.7.5 String Collating Support . . . . . . . . . . . . . . . . . . . . . . 3505.7.6 Multi-Byte Character Support . . . . . . . . . . . . . . . . . 3505.7.7 Problems With Character Sets . . . . . . . . . . . . . . . . . 351

    5.8 The MySQL Log Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 351

  • viii

    5.8.1 The Error Log. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3515.8.2 The General Query Log . . . . . . . . . . . . . . . . . . . . . . . 3525.8.3 The Update Log . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3535.8.4 The Binary Log . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3535.8.5 The Slow Query Log . . . . . . . . . . . . . . . . . . . . . . . . . . 3575.8.6 Log File Maintenance . . . . . . . . . . . . . . . . . . . . . . . . . 357

    5.9 Running Multiple MySQL Servers on the Same Machine . . 3585.9.1 Running Multiple Servers on Windows . . . . . . . . . 359

    5.9.1.1 Starting Multiple Windows Servers at theCommand Line . . . . . . . . . . . . . . . . . . . . . . . . . . 360

    5.9.1.2 Starting Multiple Windows Servers asServices . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 361

    5.9.2 Running Multiple Servers on Unix . . . . . . . . . . . . . 3635.9.3 Using Client Programs in a Multiple-Server

    Environment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3645.10 The MySQL Query Cache . . . . . . . . . . . . . . . . . . . . . . . . . . . . 365

    5.10.1 How the Query Cache Operates. . . . . . . . . . . . . . . 3655.10.2 Query Cache SELECT Options . . . . . . . . . . . . . . . . . 3675.10.3 Query Cache Configuration . . . . . . . . . . . . . . . . . . . 3675.10.4 Query Cache Status and Maintenance . . . . . . . . . 368

    6 Replication in MySQL . . . . . . . . . . . . . . . . . . . 3706.1 Introduction to Replication . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3706.2 Replication Implementation Overview. . . . . . . . . . . . . . . . . . . 3706.3 Replication Implementation Details . . . . . . . . . . . . . . . . . . . . . 371

    6.3.1 Replication Master Thread States . . . . . . . . . . . . . . 3736.3.2 Replication Slave I/O Thread States . . . . . . . . . . . 3736.3.3 Replication Slave SQL Thread States . . . . . . . . . . 3746.3.4 Replication Relay and Status Files . . . . . . . . . . . . . 375

    6.4 How to Set Up Replication . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3776.5 Replication Compatibility Between MySQL Versions . . . . . 3816.6 Upgrading a Replication Setup . . . . . . . . . . . . . . . . . . . . . . . . . 381

    6.6.1 Upgrading Replication to 4.0 or 4.1 . . . . . . . . . . . . 3816.6.2 Upgrading Replication to 5.0 . . . . . . . . . . . . . . . . . . 382

    6.7 Replication Features and Known Problems . . . . . . . . . . . . . . 3836.8 Replication Startup Options . . . . . . . . . . . . . . . . . . . . . . . . . . . 3866.9 Replication FAQ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3956.10 Troubleshooting Replication . . . . . . . . . . . . . . . . . . . . . . . . . . 4016.11 Reporting Replication Bugs . . . . . . . . . . . . . . . . . . . . . . . . . . . 402

  • ix

    7 MySQL Optimization . . . . . . . . . . . . . . . . . . . . 4037.1 Optimization Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 403

    7.1.1 MySQL Design Limitations and Tradeoffs . . . . . . 4037.1.2 Designing Applications for Portability . . . . . . . . . . 4047.1.3 What We Have Used MySQL For . . . . . . . . . . . . . . 4057.1.4 The MySQL Benchmark Suite . . . . . . . . . . . . . . . . . 4067.1.5 Using Your Own Benchmarks . . . . . . . . . . . . . . . . . . 406

    7.2 Optimizing SELECT Statements and Other Queries . . . . . . . 4077.2.1 EXPLAIN Syntax (Get Information About a SELECT)

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4087.2.2 Estimating Query Performance . . . . . . . . . . . . . . . . 4157.2.3 Speed of SELECT Queries . . . . . . . . . . . . . . . . . . . . . . 4167.2.4 How MySQL Optimizes WHERE Clauses . . . . . . . . . 4167.2.5 How MySQL Optimizes OR Clauses . . . . . . . . . . . . 4187.2.6 How MySQL Optimizes IS NULL . . . . . . . . . . . . . . . 4197.2.7 How MySQL Optimizes DISTINCT . . . . . . . . . . . . . 4207.2.8 How MySQL Optimizes LEFT JOIN and RIGHT JOIN

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4207.2.9 How MySQL Optimizes ORDER BY . . . . . . . . . . . . . . 4217.2.10 How MySQL Optimizes LIMIT . . . . . . . . . . . . . . . . 4237.2.11 How to Avoid Table Scans . . . . . . . . . . . . . . . . . . . 4237.2.12 Speed of INSERT Statements . . . . . . . . . . . . . . . . . . 4247.2.13 Speed of UPDATE Statements . . . . . . . . . . . . . . . . . . 4267.2.14 Speed of DELETE Statements . . . . . . . . . . . . . . . . . . 4267.2.15 Other Optimization Tips . . . . . . . . . . . . . . . . . . . . . 426

    7.3 Locking Issues . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4297.3.1 Locking Methods . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4297.3.2 Table Locking Issues . . . . . . . . . . . . . . . . . . . . . . . . . . 431

    7.4 Optimizing Database Structure . . . . . . . . . . . . . . . . . . . . . . . . . 4337.4.1 Design Choices . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4337.4.2 Make Your Data as Small as Possible . . . . . . . . . . 4337.4.3 Column Indexes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4347.4.4 Multiple-Column Indexes . . . . . . . . . . . . . . . . . . . . . . 4357.4.5 How MySQL Uses Indexes . . . . . . . . . . . . . . . . . . . . 4367.4.6 The MyISAM Key Cache . . . . . . . . . . . . . . . . . . . . . . . 438

    7.4.6.1 Shared Key Cache Access . . . . . . . . . . . . . 4407.4.6.2 Multiple Key Caches . . . . . . . . . . . . . . . . . 4407.4.6.3 Midpoint Insertion Strategy. . . . . . . . . . . 4417.4.6.4 Index Preloading . . . . . . . . . . . . . . . . . . . . . 4427.4.6.5 Key Cache Block Size . . . . . . . . . . . . . . . . 4437.4.6.6 Restructuring a Key Cache . . . . . . . . . . . 443

    7.4.7 How MySQL Counts Open Tables . . . . . . . . . . . . . 4447.4.8 How MySQL Opens and Closes Tables . . . . . . . . . 4447.4.9 Drawbacks to Creating Many Tables in the Same

    Database . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4457.5 Optimizing the MySQL Server . . . . . . . . . . . . . . . . . . . . . . . . . 445

    7.5.1 System Factors and Startup Parameter Tuning . . 4467.5.2 Tuning Server Parameters . . . . . . . . . . . . . . . . . . . . . 446

  • x

    7.5.3 Controlling Query Optimizer Performance . . . . . . 4497.5.4 How Compiling and Linking Affects the Speed of

    MySQL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4497.5.5 How MySQL Uses Memory . . . . . . . . . . . . . . . . . . . . 4517.5.6 How MySQL Uses DNS . . . . . . . . . . . . . . . . . . . . . . . 452

    7.6 Disk Issues . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4537.6.1 Using Symbolic Links . . . . . . . . . . . . . . . . . . . . . . . . . 454

    7.6.1.1 Using Symbolic Links for Databases onUnix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 454

    7.6.1.2 Using Symbolic Links for Tables on Unix. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 455

    7.6.1.3 Using Symbolic Links for Databases onWindows . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 456

    8 MySQL Client and Utility Programs . . . . . . 4588.1 Overview of the Client-Side Scripts and Utilities . . . . . . . . . 4588.2 myisampack, the MySQL Compressed Read-only Table

    Generator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4598.3 mysql, the Command-Line Tool . . . . . . . . . . . . . . . . . . . . . . . . 466

    8.3.1 mysql Commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4708.3.2 Executing SQL Statements from a Text File . . . . 4738.3.3 mysql Tips . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 474

    8.3.3.1 Displaying Query Results Vertically . . . 4748.3.3.2 Using the --safe-updates Option . . . . 4758.3.3.3 Disabling mysql Auto-Reconnect . . . . . . 475

    8.4 mysqladmin, Administering a MySQL Server . . . . . . . . . . . . 4768.5 The mysqlbinlog Binary Log Utility . . . . . . . . . . . . . . . . . . . 4798.6 mysqlcc, the MySQL Control Center . . . . . . . . . . . . . . . . . . . 4828.7 The mysqlcheck Table Maintenance and Repair Program

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4848.8 The mysqldump Database Backup Program . . . . . . . . . . . . . . 4878.9 The mysqlhotcopy Database Backup Program . . . . . . . . . . 4938.10 The mysqlimport Data Import Program . . . . . . . . . . . . . . . 4948.11 mysqlshow, Showing Databases, Tables, and Columns . . . 4968.12 perror, Explaining Error Codes . . . . . . . . . . . . . . . . . . . . . . . 4988.13 The replace String-replacement Utility. . . . . . . . . . . . . . . . 498

    9 MySQL Language Reference . . . . . . . . . . . . . 500

  • xi

    10 Language Structure . . . . . . . . . . . . . . . . . . . . . 50110.1 Literal Values . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 501

    10.1.1 Strings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50110.1.2 Numbers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50310.1.3 Hexadecimal Values. . . . . . . . . . . . . . . . . . . . . . . . . . 50310.1.4 Boolean Values . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50410.1.5 NULL Values . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 504

    10.2 Database, Table, Index, Column, and Alias Names . . . . . . 50410.2.1 Identifier Qualifiers . . . . . . . . . . . . . . . . . . . . . . . . . . 50610.2.2 Identifier Case Sensitivity . . . . . . . . . . . . . . . . . . . . 506

    10.3 User Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50810.4 System Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 509

    10.4.1 Structured System Variables. . . . . . . . . . . . . . . . . . 51110.5 Comment Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51210.6 Treatment of Reserved Words in MySQL . . . . . . . . . . . . . . . 513

    11 Character Set Support . . . . . . . . . . . . . . . . . . 51711.1 Character Sets and Collations in General . . . . . . . . . . . . . . 51711.2 Character Sets and Collations in MySQL . . . . . . . . . . . . . . 51811.3 Determining the Default Character Set and Collation . . . 519

    11.3.1 Server Character Set and Collation . . . . . . . . . . . 51911.3.2 Database Character Set and Collation . . . . . . . . . 52011.3.3 Table Character Set and Collation . . . . . . . . . . . . 52011.3.4 Column Character Set and Collation . . . . . . . . . . 52111.3.5 Examples of Character Set and Collation

    Assignment. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52111.3.6 Connection Character Sets and Collations . . . . . 52311.3.7 Character String Literal Character Set and

    Collation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52411.3.8 Using COLLATE in SQL Statements . . . . . . . . . . . . 52511.3.9 COLLATE Clause Precedence . . . . . . . . . . . . . . . . . . 52611.3.10 BINARY Operator . . . . . . . . . . . . . . . . . . . . . . . . . . . 52611.3.11 Some Special Cases Where the Collation

    Determination Is Tricky . . . . . . . . . . . . . . . . . . . . . . . . . 52611.3.12 Collations Must Be for the Right Character Set

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52711.3.13 An Example of the Effect of Collation . . . . . . . . 528

    11.4 Operations Affected by Character Set Support . . . . . . . . . 52911.4.1 Result Strings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52911.4.2 CONVERT() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53011.4.3 CAST() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53011.4.4 SHOW Statements. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 530

    11.5 Unicode Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53211.6 UTF8 for Metadata . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53211.7 Compatibility with Other DBMSs . . . . . . . . . . . . . . . . . . . . . 53411.8 New Character Set Configuration File Format . . . . . . . . . . 53411.9 National Character Set . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53411.10 Upgrading Character Sets from MySQL 4.0 . . . . . . . . . . . 534

  • xii

    11.10.1 4.0 Character Sets and Corresponding 4.1Character Set/Collation Pairs. . . . . . . . . . . . . . . . . . . . 535

    11.10.2 Converting 4.0 Character Columns to 4.1 Format. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 536

    11.11 Character Sets and Collations That MySQL Supports . . 53711.11.1 Unicode Character Sets . . . . . . . . . . . . . . . . . . . . . 53811.11.2 West European Character Sets . . . . . . . . . . . . . . 53911.11.3 Central European Character Sets . . . . . . . . . . . . 54011.11.4 South European and Middle East Character Sets

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54111.11.5 Baltic Character Sets . . . . . . . . . . . . . . . . . . . . . . . 54111.11.6 Cyrillic Character Sets . . . . . . . . . . . . . . . . . . . . . . 54111.11.7 Asian Character Sets . . . . . . . . . . . . . . . . . . . . . . . 542

    12 Column Types . . . . . . . . . . . . . . . . . . . . . . . . . 54412.1 Column Type Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 544

    12.1.1 Overview of Numeric Types . . . . . . . . . . . . . . . . . . 54412.1.2 Overview of Date and Time Types . . . . . . . . . . . . 54612.1.3 Overview of String Types . . . . . . . . . . . . . . . . . . . . 547

    12.2 Numeric Types . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55012.3 Date and Time Types . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 552

    12.3.1 The DATETIME, DATE, and TIMESTAMP Types . . . 55312.3.1.1 TIMESTAMP Properties Prior to MySQL 4.1

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55612.3.1.2 TIMESTAMP Properties as of MySQL 4.1

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55712.3.2 The TIME Type . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55912.3.3 The YEAR Type . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56012.3.4 Y2K Issues and Date Types . . . . . . . . . . . . . . . . . . 561

    12.4 String Types . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56112.4.1 The CHAR and VARCHAR Types . . . . . . . . . . . . . . . . 56112.4.2 The BLOB and TEXT Types . . . . . . . . . . . . . . . . . . . . 56212.4.3 The ENUM Type . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56412.4.4 The SET Type . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 565

    12.5 Column Type Storage Requirements . . . . . . . . . . . . . . . . . . . 56612.6 Choosing the Right Type for a Column . . . . . . . . . . . . . . . . 56712.7 Using Column Types from Other Database Engines . . . . . 568

  • xiii

    13 Functions and Operators . . . . . . . . . . . . . . . . 56913.1 Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 569

    13.1.1 Operator Precedence . . . . . . . . . . . . . . . . . . . . . . . . . 56913.1.2 Parentheses . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57013.1.3 Comparison Operators . . . . . . . . . . . . . . . . . . . . . . . 57013.1.4 Logical Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . 57413.1.5 Case-sensitivity Operators . . . . . . . . . . . . . . . . . . . . 576

    13.2 Control Flow Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57613.3 String Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 578

    13.3.1 String Comparison Functions . . . . . . . . . . . . . . . . . 58813.4 Numeric Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 590

    13.4.1 Arithmetic Operators . . . . . . . . . . . . . . . . . . . . . . . . 59013.4.2 Mathematical Functions. . . . . . . . . . . . . . . . . . . . . . 591

    13.5 Date and Time Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59613.6 Full-Text Search Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . 612

    13.6.1 Boolean Full-Text Searches . . . . . . . . . . . . . . . . . . . 61513.6.2 Full-Text Searches with Query Expansion . . . . . 61613.6.3 Full-Text Restrictions . . . . . . . . . . . . . . . . . . . . . . . . 61713.6.4 Fine-Tuning MySQL Full-Text Search . . . . . . . . . 61713.6.5 Full-Text Search TODO . . . . . . . . . . . . . . . . . . . . . . 619

    13.7 Cast Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62013.8 Other Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 621

    13.8.1 Bit Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62113.8.2 Encryption Functions . . . . . . . . . . . . . . . . . . . . . . . . 62213.8.3 Information Functions . . . . . . . . . . . . . . . . . . . . . . . 62613.8.4 Miscellaneous Functions . . . . . . . . . . . . . . . . . . . . . . 630

    13.9 Functions and Modifiers for Use with GROUP BY Clauses . . 63313.9.1 GROUP BY (Aggregate) Functions . . . . . . . . . . . . . . 63313.9.2 GROUP BY Modifiers . . . . . . . . . . . . . . . . . . . . . . . . . . 63513.9.3 GROUP BY with Hidden Fields . . . . . . . . . . . . . . . . . 638

    14 SQL Statement Syntax . . . . . . . . . . . . . . . . . . 64014.1 Data Manipulation Statements . . . . . . . . . . . . . . . . . . . . . . . . 640

    14.1.1 DELETE Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64014.1.2 DO Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64214.1.3 HANDLER Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64214.1.4 INSERT Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 644

    14.1.4.1 INSERT ... SELECT Syntax . . . . . . . . . . 64714.1.4.2 INSERT DELAYED Syntax . . . . . . . . . . . . . 647

    14.1.5 LOAD DATA INFILE Syntax . . . . . . . . . . . . . . . . . . . . 64914.1.6 REPLACE Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65614.1.7 SELECT Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 657

    14.1.7.1 JOIN Syntax . . . . . . . . . . . . . . . . . . . . . . . . 66314.1.7.2 UNION Syntax . . . . . . . . . . . . . . . . . . . . . . . 665

    14.1.8 Subquery Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66614.1.8.1 The Subquery as Scalar Operand . . . . . 66714.1.8.2 Comparisons Using Subqueries . . . . . . . 66714.1.8.3 Subqueries with ANY, IN, and SOME . . . 668

  • xiv

    14.1.8.4 Subqueries with ALL. . . . . . . . . . . . . . . . . 66914.1.8.5 Correlated Subqueries . . . . . . . . . . . . . . . 66914.1.8.6 EXISTS and NOT EXISTS . . . . . . . . . . . . . 67014.1.8.7 Row Subqueries . . . . . . . . . . . . . . . . . . . . . 67114.1.8.8 Subqueries in the FROM clause . . . . . . . . 67114.1.8.9 Subquery Errors . . . . . . . . . . . . . . . . . . . . 67214.1.8.10 Optimizing Subqueries . . . . . . . . . . . . . 67314.1.8.11 Rewriting Subqueries as Joins for Earlier

    MySQL Versions . . . . . . . . . . . . . . . . . . . . . . . . . 67414.1.9 TRUNCATE Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67514.1.10 UPDATE Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 676

    14.2 Data Definition Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . 67814.2.1 ALTER DATABASE Syntax . . . . . . . . . . . . . . . . . . . . . . 67814.2.2 ALTER TABLE Syntax . . . . . . . . . . . . . . . . . . . . . . . . . 67814.2.3 CREATE DATABASE Syntax . . . . . . . . . . . . . . . . . . . . . 68314.2.4 CREATE INDEX Syntax . . . . . . . . . . . . . . . . . . . . . . . . 68314.2.5 CREATE TABLE Syntax . . . . . . . . . . . . . . . . . . . . . . . . 684

    14.2.5.1 Silent Column Specification Changes . . 69514.2.6 DROP DATABASE Syntax . . . . . . . . . . . . . . . . . . . . . . . 69614.2.7 DROP INDEX Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . 69714.2.8 DROP TABLE Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . 69714.2.9 RENAME TABLE Syntax . . . . . . . . . . . . . . . . . . . . . . . . 697

    14.3 MySQL Utility Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69814.3.1 DESCRIBE Syntax (Get Information About

    Columns) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69814.3.2 USE Syntax. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 699

    14.4 MySQL Transactional and Locking Statements . . . . . . . . . 69914.4.1 START TRANSACTION, COMMIT, and ROLLBACK Syntax

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69914.4.2 Statements That Cannot Be Rolled Back . . . . . . 70014.4.3 Statements That Cause an Implicit Commit . . . 70014.4.4 SAVEPOINT and ROLLBACK TO SAVEPOINT Syntax

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70114.4.5 LOCK TABLES and UNLOCK TABLES Syntax . . . . . . 70114.4.6 SET TRANSACTION Syntax . . . . . . . . . . . . . . . . . . . . . 704

    14.5 Database Administration Statements . . . . . . . . . . . . . . . . . . 70414.5.1 Account Management Statements . . . . . . . . . . . . . 704

    14.5.1.1 DROP USER Syntax . . . . . . . . . . . . . . . . . . . 70414.5.1.2 GRANT and REVOKE Syntax . . . . . . . . . . . 70514.5.1.3 SET PASSWORD Syntax . . . . . . . . . . . . . . . 711

    14.5.2 Table Maintenance Statements . . . . . . . . . . . . . . . 71214.5.2.1 ANALYZE TABLE Syntax . . . . . . . . . . . . . . 71214.5.2.2 BACKUP TABLE Syntax . . . . . . . . . . . . . . . 71214.5.2.3 CHECK TABLE Syntax . . . . . . . . . . . . . . . . 71314.5.2.4 CHECKSUM TABLE Syntax . . . . . . . . . . . . . 71414.5.2.5 OPTIMIZE TABLE Syntax . . . . . . . . . . . . . 71514.5.2.6 REPAIR TABLE Syntax . . . . . . . . . . . . . . . 71514.5.2.7 RESTORE TABLE Syntax . . . . . . . . . . . . . . 716

  • xv

    14.5.3 SET and SHOW Syntax . . . . . . . . . . . . . . . . . . . . . . . . 71714.5.3.1 SET Syntax . . . . . . . . . . . . . . . . . . . . . . . . . 71714.5.3.2 SHOW CHARACTER SET Syntax . . . . . . . . . 72214.5.3.3 SHOW COLLATION Syntax . . . . . . . . . . . . . 72214.5.3.4 SHOW COLUMNS Syntax . . . . . . . . . . . . . . . 72314.5.3.5 SHOW CREATE DATABASE Syntax . . . . . . . 72314.5.3.6 SHOW CREATE TABLE Syntax . . . . . . . . . . 72314.5.3.7 SHOW DATABASES Syntax . . . . . . . . . . . . . 72414.5.3.8 SHOW ENGINES Syntax . . . . . . . . . . . . . . . 72414.5.3.9 SHOW ERRORS Syntax . . . . . . . . . . . . . . . . 72514.5.3.10 SHOW GRANTS Syntax . . . . . . . . . . . . . . . 72514.5.3.11 SHOW INDEX Syntax. . . . . . . . . . . . . . . . . 72614.5.3.12 SHOW INNODB STATUS Syntax . . . . . . . . 72714.5.3.13 SHOW LOGS Syntax . . . . . . . . . . . . . . . . . . 72714.5.3.14 SHOW PRIVILEGES Syntax . . . . . . . . . . . 72714.5.3.15 SHOW PROCESSLIST Syntax . . . . . . . . . . 72914.5.3.16 SHOW STATUS Syntax . . . . . . . . . . . . . . . 73114.5.3.17 SHOW TABLE STATUS Syntax . . . . . . . . . 73214.5.3.18 SHOW TABLES Syntax . . . . . . . . . . . . . . . 73314.5.3.19 SHOW VARIABLES Syntax . . . . . . . . . . . . 73414.5.3.20 SHOW WARNINGS Syntax . . . . . . . . . . . . . 735

    14.5.4 Other Administrative Statements . . . . . . . . . . . . . 73714.5.4.1 CACHE INDEX Syntax . . . . . . . . . . . . . . . . 73714.5.4.2 FLUSH Syntax . . . . . . . . . . . . . . . . . . . . . . . 73814.5.4.3 KILL Syntax . . . . . . . . . . . . . . . . . . . . . . . . 73914.5.4.4 LOAD INDEX INTO CACHE Syntax . . . . . . 74014.5.4.5 RESET Syntax . . . . . . . . . . . . . . . . . . . . . . . 741

    14.6 Replication Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74114.6.1 SQL Statements for Controlling Master Servers

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74114.6.1.1 PURGE MASTER LOGS Syntax . . . . . . . . . . 74214.6.1.2 RESET MASTER Syntax . . . . . . . . . . . . . . . 74214.6.1.3 SET SQL_LOG_BIN Syntax . . . . . . . . . . . . 74214.6.1.4 SHOW BINLOG EVENTS Syntax . . . . . . . . . 74314.6.1.5 SHOW MASTER LOGS Syntax . . . . . . . . . . . 74314.6.1.6 SHOW MASTER STATUS Syntax . . . . . . . . . 74314.6.1.7 SHOW SLAVE HOSTS Syntax . . . . . . . . . . . 743

    14.6.2 SQL Statements for Controlling Slave Servers . . 74314.6.2.1 CHANGE MASTER TO Syntax . . . . . . . . . . . 74314.6.2.2 LOAD DATA FROM MASTER Syntax . . . . . . 74614.6.2.3 LOAD TABLE tbl_name FROM MASTER

    Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74614.6.2.4 MASTER_POS_WAIT() Syntax . . . . . . . . . 74714.6.2.5 RESET SLAVE Syntax . . . . . . . . . . . . . . . . 74714.6.2.6 SET GLOBAL SQL_SLAVE_SKIP_COUNTER

    Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74714.6.2.7 SHOW SLAVE STATUS Syntax . . . . . . . . . . 74714.6.2.8 START SLAVE Syntax . . . . . . . . . . . . . . . . 751

  • xvi

    14.6.2.9 STOP SLAVE Syntax . . . . . . . . . . . . . . . . . . 752

    15 MySQL Storage Engines and Table Types. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75315.1 The MyISAM Storage Engine . . . . . . . . . . . . . . . . . . . . . . . . . . . 754

    15.1.1 MyISAM Startup Options. . . . . . . . . . . . . . . . . . . . . . 75615.1.2 Space Needed for Keys . . . . . . . . . . . . . . . . . . . . . . . 75715.1.3 MyISAM Table Storage Formats . . . . . . . . . . . . . . . . 758

    15.1.3.1 Static (Fixed-Length) TableCharacteristics. . . . . . . . . . . . . . . . . . . . . . . . . . . 758

    15.1.3.2 Dynamic Table Characteristics . . . . . . . 75915.1.3.3 Compressed Table Characteristics . . . . 760

    15.1.4 MyISAM Table Problems . . . . . . . . . . . . . . . . . . . . . . 76015.1.4.1 Corrupted MyISAM Tables . . . . . . . . . . . . 76015.1.4.2 Problems from Tables Not Being Closed

    Properly . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76115.2 The MERGE Storage Engine . . . . . . . . . . . . . . . . . . . . . . . . . . . . 762

    15.2.1 MERGE Table Problems . . . . . . . . . . . . . . . . . . . . . . . 76415.3 The MEMORY (HEAP) Storage Engine . . . . . . . . . . . . . . . . . . . . 76515.4 The BDB (BerkeleyDB) Storage Engine . . . . . . . . . . . . . . . . . 767

    15.4.1 Operating Systems Supported by BDB . . . . . . . . . 76815.4.2 Installing BDB . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76815.4.3 BDB Startup Options . . . . . . . . . . . . . . . . . . . . . . . . . 76815.4.4 Characteristics of BDB Tables . . . . . . . . . . . . . . . . . 77015.4.5 Things We Need to Fix for BDB . . . . . . . . . . . . . . . 77115.4.6 Restrictions on BDB Tables . . . . . . . . . . . . . . . . . . . 77215.4.7 Errors That May Occur When Using BDB Tables

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77215.5 The ISAM Storage Engine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 772

    16 The InnoDB Storage Engine . . . . . . . . . . . . . . 77416.1 InnoDB Overview. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77416.2 InnoDB Contact Information . . . . . . . . . . . . . . . . . . . . . . . . . . 77416.3 InnoDB in MySQL 3.23 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77516.4 InnoDB Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77516.5 InnoDB Startup Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78016.6 Creating the InnoDB Tablespace . . . . . . . . . . . . . . . . . . . . . . . 783

    16.6.1 Dealing with InnoDB Initialization Problems . . . 78516.7 Creating InnoDB Tables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 785

    16.7.1 How to Use Transactions in InnoDB with DifferentAPIs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 785

    16.7.2 Converting MyISAM Tables to InnoDB . . . . . . . . . . 78616.7.3 How an AUTO_INCREMENT Column Works in InnoDB

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78716.7.4 FOREIGN KEY Constraints . . . . . . . . . . . . . . . . . . . . . 78816.7.5 InnoDB and MySQL Replication . . . . . . . . . . . . . . 79216.7.6 Using Per-Table Tablespaces . . . . . . . . . . . . . . . . . 792

  • xvii

    16.8 Adding and Removing InnoDB Data and Log Files . . . . . . 79416.9 Backing Up and Recovering an InnoDB Database . . . . . . . 795

    16.9.1 Forcing Recovery . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79716.9.2 Checkpoints . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 798

    16.10 Moving an InnoDB Database to Another Machine . . . . . . 79816.11 InnoDB Transaction Model and Locking . . . . . . . . . . . . . . . 799

    16.11.1 InnoDB and AUTOCOMMIT . . . . . . . . . . . . . . . . . . . . 79916.11.2 InnoDB and TRANSACTION ISOLATION LEVEL . . 79916.11.3 Consistent Non-Locking Read . . . . . . . . . . . . . . . 80116.11.4 Locking Reads SELECT ... FOR UPDATE and

    SELECT ... LOCK IN SHARE MODE . . . . . . . . . . . . . . . . . 80116.11.5 Next-Key Locking: Avoiding the Phantom

    Problem . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80216.11.6 An Example of How the Consistent Read Works in

    InnoDB . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80316.11.7 Locks Set by Different SQL Statements in InnoDB

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80416.11.8 When Does MySQL Implicitly Commit or Roll

    Back a Transaction? . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80516.11.9 Deadlock Detection and Rollback . . . . . . . . . . . . 80616.11.10 How to Cope with Deadlocks . . . . . . . . . . . . . . . 806

    16.12 InnoDB Performance Tuning Tips. . . . . . . . . . . . . . . . . . . . . 80716.12.1 SHOW INNODB STATUS and the InnoDB Monitors

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80916.13 Implementation of Multi-Versioning . . . . . . . . . . . . . . . . . . 81416.14 Table and Index Structures . . . . . . . . . . . . . . . . . . . . . . . . . . 814

    16.14.1 Physical Structure of an Index . . . . . . . . . . . . . . . 81516.14.2 Insert Buffering . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81516.14.3 Adaptive Hash Indexes. . . . . . . . . . . . . . . . . . . . . . 81616.14.4 Physical Record Structure . . . . . . . . . . . . . . . . . . . 816

    16.15 File Space Management and Disk I/O . . . . . . . . . . . . . . . . 81716.15.1 Disk I/O . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81716.15.2 Using Raw Devices for the Tablespace . . . . . . . . 81716.15.3 File Space Management . . . . . . . . . . . . . . . . . . . . . 81816.15.4 Defragmenting a Table . . . . . . . . . . . . . . . . . . . . . . 818

    16.16 Error Handling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81916.16.1 InnoDB Error Codes . . . . . . . . . . . . . . . . . . . . . . . . 81916.16.2 Operating System Error Codes . . . . . . . . . . . . . . 820

    16.17 Restrictions on InnoDB Tables . . . . . . . . . . . . . . . . . . . . . . . . 82416.18 InnoDB Troubleshooting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 826

    16.18.1 Troubleshooting InnoDB Data DictionaryOperations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 826

  • xviii

    17 MySQL Cluster . . . . . . . . . . . . . . . . . . . . . . . . 82817.1 MySQL Cluster Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82817.2 Basic MySQL Cluster Concepts . . . . . . . . . . . . . . . . . . . . . . . 82817.3 MySQL Cluster Configuration. . . . . . . . . . . . . . . . . . . . . . . . . 829

    17.3.1 Building the Software . . . . . . . . . . . . . . . . . . . . . . . . 83017.3.2 Installing the Software . . . . . . . . . . . . . . . . . . . . . . . 830

    17.4 Process Management in MySQL Cluster . . . . . . . . . . . . . . . 83117.4.1 MySQL Server Process Usage for MySQL Cluster

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83117.4.2 ndbd, the Storage Engine Node Process . . . . . . . 83117.4.3 ndb_mgmd, the Management Server Process . . . . 83317.4.4 ndb_mgm, the Management Client Process . . . . . 83317.4.5 Command Options for MySQL Cluster Processes

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83417.4.5.1 MySQL Cluster-Related Command

    Options for mysqld . . . . . . . . . . . . . . . . . . . . . . 83417.4.5.2 Command Options for ndbd . . . . . . . . . 83417.4.5.3 Command Options for ndb_mgmd . . . . . 83517.4.5.4 Command Options for ndb_mgm . . . . . . 835

    17.5 Management of MySQL Cluster . . . . . . . . . . . . . . . . . . . . . . . 835

    18 Introduction to MaxDB . . . . . . . . . . . . . . . . . 83718.1 History of MaxDB . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83718.2 Licensing and Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83718.3 MaxDB-Related Links . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83718.4 Basic Concepts of MaxDB . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83718.5 Feature Differences Between MaxDB and MySQL . . . . . . 83818.6 Interoperability Features Between MaxDB and MySQL . . 83818.7 Reserved Words in MaxDB . . . . . . . . . . . . . . . . . . . . . . . . . . . 839

    19 Spatial Extensions in MySQL . . . . . . . . . . . 84319.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84319.2 The OpenGIS Geometry Model . . . . . . . . . . . . . . . . . . . . . . . 843

    19.2.1 The Geometry Class Hierarchy . . . . . . . . . . . . . . . 84419.2.2 Class Geometry. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84519.2.3 Class Point . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84619.2.4 Class Curve . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84619.2.5 Class LineString . . . . . . . . . . . . . . . . . . . . . . . . . . . 84719.2.6 Class Surface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84719.2.7 Class Polygon . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84719.2.8 Class GeometryCollection . . . . . . . . . . . . . . . . . . 84819.2.9 Class MultiPoint . . . . . . . . . . . . . . . . . . . . . . . . . . . 84819.2.10 Class MultiCurve . . . . . . . . . . . . . . . . . . . . . . . . . . 84819.2.11 Class MultiLineString . . . . . . . . . . . . . . . . . . . . . 84919.2.12 Class MultiSurface . . . . . . . . . . . . . . . . . . . . . . . . 84919.2.13 Class MultiPolygon . . . . . . . . . . . . . . . . . . . . . . . . 849

    19.3 Supported Spatial Data Formats . . . . . . . . . . . . . . . . . . . . . . 850

  • xix

    19.3.1 Well-Known Text (WKT) Format . . . . . . . . . . . . . 85019.3.2 Well-Known Binary (WKB) Format. . . . . . . . . . . 851

    19.4 Creating a Spatially Enabled MySQL Database. . . . . . . . . 85119.4.1 MySQL Spatial Data Types . . . . . . . . . . . . . . . . . . 85219.4.2 Creating Spatial Values . . . . . . . . . . . . . . . . . . . . . . 852

    19.4.2.1 Creating Geometry Values Using WKTFunctions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 852

    19.4.2.2 Creating Geometry Values Using WKBFunctions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 853

    19.4.2.3 Creating Geometry Values UsingMySQL-Specific Functions . . . . . . . . . . . . . . . . 854

    19.4.3 Creating Spatial Columns . . . . . . . . . . . . . . . . . . . . 85519.4.4 Populating Spatial Columns . . . . . . . . . . . . . . . . . . 85519.4.5 Fetching Spatial Data . . . . . . . . . . . . . . . . . . . . . . . . 857

    19.4.5.1 Fetching Spatial Data in Internal Format. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 857

    19.4.5.2 Fetching Spatial Data in WKT Format. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 857

    19.4.5.3 Fetching Spatial Data in WKB Format. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 857

    19.5 Analyzing Spatial Information . . . . . . . . . . . . . . . . . . . . . . . . 85719.5.1 Geometry Format Conversion Functions . . . . . . . 85819.5.2 Geometry Functions . . . . . . . . . . . . . . . . . . . . . . . . . 858

    19.5.2.1 General Geometry Functions . . . . . . . . . 85819.5.2.2 Point Functions . . . . . . . . . . . . . . . . . . . . 86019.5.2.3 LineString Functions . . . . . . . . . . . . . . . 86019.5.2.4 MultiLineString Functions . . . . . . . . . 86219.5.2.5 Polygon Functions . . . . . . . . . . . . . . . . . . 86219.5.2.6 MultiPolygon Functions . . . . . . . . . . . . 86319.5.2.7 GeometryCollection Functions . . . . . . 864

    19.5.3 Functions That Create New Geometries fromExisting Ones . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 864

    19.5.3.1 Geometry Functions That Produce NewGeometries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 865

    19.5.3.2 Spatial Operators . . . . . . . . . . . . . . . . . . . 86519.5.4 Functions for Testing Spatial Relations Between

    Geometric Objects . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86519.5.5 Relations on Geometry Minimal Bounding

    Rectangles (MBRs) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86519.5.6 Functions That Test Spatial Relationships Between

    Geometries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86619.6 Optimizing Spatial Analysis . . . . . . . . . . . . . . . . . . . . . . . . . . . 868

    19.6.1 Creating Spatial Indexes . . . . . . . . . . . . . . . . . . . . . 86819.6.2 Using a Spatial Index . . . . . . . . . . . . . . . . . . . . . . . . 869

    19.7 MySQL Conformance and Compatibility . . . . . . . . . . . . . . . 87119.7.1 GIS Features That Are Not Yet Implemented . . 871

  • xx

    20 Stored Procedures and Functions . . . . . . . . 87220.1 Stored Procedure Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 872

    20.1.1 Maintaining Stored Procedures . . . . . . . . . . . . . . . 87320.1.1.1 CREATE PROCEDURE and CREATE FUNCTION

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87320.1.1.2 ALTER PROCEDURE and ALTER FUNCTION

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87520.1.1.3 DROP PROCEDURE and DROP FUNCTION . . 87520.1.1.4 SHOW CREATE PROCEDURE and SHOW CREATE

    FUNCTION . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87520.1.2 SHOW PROCEDURE STATUS and SHOW FUNCTION

    STATUS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87620.1.3 CALL. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87620.1.4 BEGIN ... END Compound Statement . . . . . . . . . 87620.1.5 DECLARE Statement . . . . . . . . . . . . . . . . . . . . . . . . . . 87620.1.6 Variables in Stored Procedures . . . . . . . . . . . . . . . 876

    20.1.6.1 DECLARE Local Variables . . . . . . . . . . . . . 87720.1.6.2 Variable SET Statement. . . . . . . . . . . . . . 87720.1.6.3 SELECT ... INTO Statement . . . . . . . . . 877

    20.1.7 Conditions and Handlers . . . . . . . . . . . . . . . . . . . . . 87720.1.7.1 DECLARE Conditions . . . . . . . . . . . . . . . . . 87720.1.7.2 DECLARE Handlers . . . . . . . . . . . . . . . . . . . 877

    20.1.8 Cursors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87920.1.8.1 Declaring Cursors . . . . . . . . . . . . . . . . . . . 88020.1.8.2 Cursor OPEN Statement . . . . . . . . . . . . . . 88020.1.8.3 Cursor FETCH Statement . . . . . . . . . . . . . 88020.1.8.4 Cursor CLOSE Statement . . . . . . . . . . . . . 880

    20.1.9 Flow Control Constructs . . . . . . . . . . . . . . . . . . . . . 88020.1.9.1 IF Statement . . . . . . . . . . . . . . . . . . . . . . . 88020.1.9.2 CASE Statement . . . . . . . . . . . . . . . . . . . . . 88020.1.9.3 LOOP Statement . . . . . . . . . . . . . . . . . . . . . 88120.1.9.4 LEAVE Statement . . . . . . . . . . . . . . . . . . . . 88120.1.9.5 ITERATE Statement . . . . . . . . . . . . . . . . . 88120.1.9.6 REPEAT Statement. . . . . . . . . . . . . . . . . . . 88220.1.9.7 WHILE Statement . . . . . . . . . . . . . . . . . . . . 882

    21 MySQL APIs. . . . . . . . . . . . . . . . . . . . . . . . . . . 88421.1 MySQL Program Development Utilities . . . . . . . . . . . . . . . . 884

    21.1.1 msql2mysql, Convert mSQL Programs for Use withMySQL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 884

    21.1.2 mysql_config, Get compile options for compilingclients . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 884

    21.2 MySQL C API . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88521.2.1 C API Data types . . . . . . . . . . . . . . . . . . . . . . . . . . . 88621.2.2 C API Function Overview . . . . . . . . . . . . . . . . . . . . 88921.2.3 C API Function Descriptions . . . . . . . . . . . . . . . . . 893

    21.2.3.1 mysql_affected_rows() . . . . . . . . . . . . 89321.2.3.2 mysql_change_user() . . . . . . . . . . . . . . 894

  • xxi

    21.2.3.3 mysql_character_set_name(). . . . . . . 89521.2.3.4 mysql_close() . . . . . . . . . . . . . . . . . . . . . 89621.2.3.5 mysql_connect() . . . . . . . . . . . . . . . . . . . 89621.2.3.6 mysql_create_db() . . . . . . . . . . . . . . . . 89721.2.3.7 mysql_data_seek() . . . . . . . . . . . . . . . . 89721.2.3.8 mysql_debug() . . . . . . . . . . . . . . . . . . . . . 89821.2.3.9 mysql_drop_db() . . . . . . . . . . . . . . . . . . . 89821.2.3.10 mysql_dump_debug_info() . . . . . . . . . 89921.2.3.11 mysql_eof() . . . . . . . . . . . . . . . . . . . . . . 90021.2.3.12 mysql_errno() . . . . . . . . . . . . . . . . . . . . 90121.2.3.13 mysql_error() . . . . . . . . . . . . . . . . . . . . 90221.2.3.14 mysql_escape_string() . . . . . . . . . . . 90221.2.3.15 mysql_fetch_field() . . . . . . . . . . . . . 90221.2.3.16 mysql_fetch_fields() . . . . . . . . . . . . 90321.2.3.17 mysql_fetch_field_direct() . . . . . 90421.2.3.18 mysql_fetch_lengths() . . . . . . . . . . . 90521.2.3.19 mysql_fetch_row() . . . . . . . . . . . . . . . 90621.2.3.20 mysql_field_count() . . . . . . . . . . . . . 90721.2.3.21 mysql_field_seek() . . . . . . . . . . . . . . 90821.2.3.22 mysql_field_tell() . . . . . . . . . . . . . . 90821.2.3.23 mysql_free_result() . . . . . . . . . . . . . 90921.2.3.24 mysql_get_client_info() . . . . . . . . . 90921.2.3.25 mysql_get_client_version() . . . . . 91021.2.3.26 mysql_get_host_info() . . . . . . . . . . . 91021.2.3.27 mysql_get_proto_info() . . . . . . . . . . 91021.2.3.28 mysql_get_server_info() . . . . . . . . . 91121.2.3.29 mysql_get_server_version() . . . . . 91121.2.3.30 mysql_info() . . . . . . . . . . . . . . . . . . . . . 91221.2.3.31 mysql_init() . . . . . . . . . . . . . . . . . . . . . 91221.2.3.32 mysql_insert_id() . . . . . . . . . . . . . . . 91321.2.3.33 mysql_kill() . . . . . . . . . . . . . . . . . . . . . 91421.2.3.34 mysql_list_dbs() . . . . . . . . . . . . . . . . . 91421.2.3.35 mysql_list_fields() . . . . . . . . . . . . . 91521.2.3.36 mysql_list_processes() . . . . . . . . . . 91621.2.3.37 mysql_list_tables() . . . . . . . . . . . . . 91621.2.3.38 mysql_num_fields() . . . . . . . . . . . . . . 91721.2.3.39 mysql_num_rows() . . . . . . . . . . . . . . . . . 91821.2.3.40 mysql_options() . . . . . . . . . . . . . . . . . . 91921.2.3.41 mysql_ping() . . . . . . . . . . . . . . . . . . . . . 92121.2.3.42 mysql_query() . . . . . . . . . . . . . . . . . . . . 92221.2.3.43 mysql_real_connect() . . . . . . . . . . . . 92221.2.3.44 mysql_real_escape_string() . . . . . 92521.2.3.45 mysql_real_query() . . . . . . . . . . . . . . 92621.2.3.46 mysql_reload() . . . . . . . . . . . . . . . . . . . 92721.2.3.47 mysql_row_seek() . . . . . . . . . . . . . . . . . 92821.2.3.48 mysql_row_tell() . . . . . . . . . . . . . . . . . 92821.2.3.49 mysql_select_db() . . . . . . . . . . . . . . . 92921.2.3.50 mysql_set_server_option() . . . . . . . 929

  • xxii

    21.2.3.51 mysql_shutdown() . . . . . . . . . . . . . . . . . 93021.2.3.52 mysql_sqlstate() . . . . . . . . . . . . . . . . . 93121.2.3.53 mysql_ssl_set() . . . . . . . . . . . . . . . . . . 93121.2.3.54 mysql_stat() . . . . . . . . . . . . . . . . . . . . . 93221.2.3.55 mysql_store_result() . . . . . . . . . . . . 93221.2.3.56 mysql_thread_id() . . . . . . . . . . . . . . . 93321.2.3.57 mysql_use_result() . . . . . . . . . . . . . . 93421.2.3.58 mysql_warning_count() . . . . . . . . . . . 93521.2.3.59 mysql_commit() . . . . . . . . . . . . . . . . . . . 93521.2.3.60 mysql_rollback() . . . . . . . . . . . . . . . . . 93621.2.3.61 mysql_autocommit() . . . . . . . . . . . . . . 93621.2.3.62 mysql_more_results() . . . . . . . . . . . . 93621.2.3.63 mysql_next_result() . . . . . . . . . . . . . 937

    21.2.4 C API Prepared Statements . . . . . . . . . . . . . . . . . . 93821.2.5 C API Prepared Statement Data types . . . . . . . . 93821.2.6 C API Prepared Statement Function Overview

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 94121.2.7 C API Prepared Statement Function Descriptions

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 94421.2.7.1 mysql_stmt_init() . . . . . . . . . . . . . . . . 94421.2.7.2 mysql_stmt_bind_param() . . . . . . . . . . 94421.2.7.3 mysql_stmt_bind_result() . . . . . . . . . 94521.2.7.4 mysql_stmt_execute() . . . . . . . . . . . . . 94621.2.7.5 mysql_stmt_fetch() . . . . . . . . . . . . . . . 95121.2.7.6 mysql_stmt_fetch_column() . . . . . . . . 95621.2.7.7 mysql_stmt_result_metadata() . . . . 95621.2.7.8 mysql_stmt_param_count() . . . . . . . . . 95721.2.7.9 mysql_stmt_param_metadata() . . . . . 95821.2.7.10 mysql_stmt_prepare() . . . . . . . . . . . . 95821.2.7.11 mysql_stmt_send_long_data() . . . . 95921.2.7.12 mysql_stmt_affected_rows() . . . . . 96121.2.7.13 mysql_stmt_insert_id() . . . . . . . . . . 96221.2.7.14 mysql_stmt_close() . . . . . . . . . . . . . . 96221.2.7.15 mysql_stmt_data_seek() . . . . . . . . . . 96321.2.7.16 mysql_stmt_errno() . . . . . . . . . . . . . . 96321.2.7.17 mysql_stmt_error() . . . . . . . . . . . . . . 96421.2.7.18 mysql_stmt_free_result() . . . . . . . . 96521.2.7.19 mysql_stmt_num_rows() . . . . . . . . . . . 96521.2.7.20 mysql_stmt_reset() . . . . . . . . . . . . . . 96521.2.7.21 mysql_stmt_row_seek() . . . . . . . . . . . 96621.2.7.22 mysql_stmt_row_tell() . . . . . . . . . . . 96621.2.7.23 mysql_stmt_sqlstate() . . . . . . . . . . . 96721.2.7.24 mysql_stmt_store_result() . . . . . . . 96721.2.7.25 mysql_stmt_attr_set() . . . . . . . . . . . 96821.2.7.26 mysql_stmt_attr_get() . . . . . . . . . . . 969

    21.2.8 C API Handling of Multiple Query Execution . . 96921.2.9 C API Handling of Date and Time Values . . . . . 97021.2.10 C API Threaded Function Descriptions . . . . . . 972

  • xxiii

    21.2.10.1 my_init() . . . . . . . . . . . . . . . . . . . . . . . . 97221.2.10.2 mysql_thread_init() . . . . . . . . . . . . . 97221.2.10.3 mysql_thread_end() . . . . . . . . . . . . . . 97221.2.10.4 mysql_thread_safe() . . . . . . . . . . . . . 973

    21.2.11 C API Embedded Server Function Descriptions. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 973

    21.2.11.1 mysql_server_init() . . . . . . . . . . . . . 97321.2.11.2 mysql_server_end() . . . . . . . . . . . . . . 974

    21.2.12 Common questions and problems when using theC API . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 975

    21.2.12.1 Why mysql_store_result() SometimesReturns NULL After mysql_query() ReturnsSuccess . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 975

    21.2.12.2 What Results You Can Get from a Query. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 975

    21.2.12.3 How to Get the Unique ID for the LastInserted Row . . . . . . . . . . . . . . . . . . . . . . . . . . . . 976

    21.2.12.4 Problems Linking with the C API . . . 97621.2.13 Building Client Programs . . . . . . . . . . . . . . . . . . . 97721.2.14 How to Make a Threaded Client . . . . . . . . . . . . . 97721.2.15 libmysqld, the Embedded MySQL Server Library

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97921.2.15.1 Overview of the Embedded MySQL

    Server Library . . . . . . . . . . . . . . . . . . . . . . . . . . . 97921.2.15.2 Compiling Programs with libmysqld

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97921.2.15.3 Restrictions when using the Embedded

    MySQL Server . . . . . . . . . . . . . . . . . . . . . . . . . . . 97921.2.15.4 Using Option Files with the Embedded

    Server. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98021.2.15.5 Things left to do in Embedded Server

    (TODO) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98021.2.15.6 A Simple Embedded Server Example

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98021.2.15.7 Licensing the Embedded Server . . . . . 984

    21.3 MySQL ODBC Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98421.3.1 How to Install MyODBC . . . . . . . . . . . . . . . . . . . . . 98421.3.2 How to Fill in the Various Fields in the ODBC

    Administrator Program . . . . . . . . . . . . . . . . . . . . . . . . . 98521.3.3 Connect parameters for MyODBC . . . . . . . . . . . . 98621.3.4 How to Report Problems with MyODBC . . . . . . 98721.3.5 Programs Known to Work with MyODBC . . . . . 98821.3.6 How to Get the Value of an AUTO_INCREMENT

    Column in ODBC. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99221.3.7 Reporting Problems with MyODBC. . . . . . . . . . . 993

    21.4 MySQL Java Connectivity (JDBC) . . . . . . . . . . . . . . . . . . . . 99421.5 MySQL PHP API . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 994

    21.5.1 Common Problems with MySQL and PHP . . . . 994

  • xxiv

    21.6 MySQL Perl API . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99421.7 MySQL C++ API . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 995

    21.7.1 Borland C++ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99521.8 MySQL Python API . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99521.9 MySQL Tcl API . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99621.10 MySQL Eiffel Wrapper . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 996

    22 Error Handling in MySQL . . . . . . . . . . . . . . 997

    23 Extending MySQL. . . . . . . . . . . . . . . . . . . . . 101923.1 MySQL Internals . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1019

    23.1.1 MySQL Threads . . . . . . . . . . . . . . . . . . . . . . . . . . . 101923.1.2 MySQL Test Suite . . . . . . . . . . . . . . . . . . . . . . . . . . 1019

    23.1.2.1 Running the MySQL Test Suite . . . . . 102023.1.2.2 Extending the MySQL Test Suite . . . 102023.1.2.3 Reporting Bugs in the MySQL Test Suite

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 102123.2 Adding New Functions to MySQL . . . . . . . . . . . . . . . . . . . . 1022

    23.2.1 CREATE FUNCTION/DROP FUNCTION Syntax . . . . 102323.2.2 Adding a New User-defined Function . . . . . . . . . 1023

    23.2.2.1 UDF Calling Sequences for simplefunctions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1025

    23.2.2.2 UDF Calling Sequences for aggregatefunctions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1026

    23.2.2.3 Argument Processing . . . . . . . . . . . . . . . 102723.2.2.4 Return Values and Error Handling . . 102823.2.2.5 Compiling and Installing User-defined

    Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 102923.2.3 Adding a New Native Function . . . . . . . . . . . . . . 1031

    23.3 Adding New Procedures to MySQL . . . . . . . . . . . . . . . . . . . 103223.3.1 Procedure Analyse. . . . . . . . . . . . . . . . . . . . . . . . . . 103223.3.2 Writing a Procedure . . . . . . . . . . . . . . . . . . . . . . . . 1032

    Appendix A Problems and Common Errors. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1033A.1 How to Determine What Is Causing a Problem . . . . . . . . 1033A.2 Common Errors When Using MySQL Programs . . . . . . . . 1034

    A.2.1 Access denied . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1034A.2.2 Can’t connect to [local] MySQL server . . . . 1034A.2.3 Client does not support authentication

    protocol . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1036A.2.4 Password Fails When Entered Interactively . . . 1037A.2.5 Host ’host_name’ is blocked . . . . . . . . . . . . . . . 1037A.2.6 Too many connections . . . . . . . . . . . . . . . . . . . . . . 1038A.2.7 Out of memory . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1038A.2.8 MySQL server has gone away . . . . . . . . . . . . . . . . 1038A.2.9 Packet too large . . . . . . . . . . . . . . . . . . . . . . . . . . 1039

  • xxv

    A.2.10 Communication Errors and Aborted Connections. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1040

    A.2.11 The table is full . . . . . . . . . . . . . . . . . . . . . . . . . 1041A.2.12 Can’t create/write to file . . . . . . . . . . . . . . . 1042A.2.13 Commands out of sync . . . . . . . . . . . . . . . . . . . . . 1042A.2.14 Ignoring user . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1043A.2.15 Table ’tbl_name’ doesn’t exist . . . . . . . . . . 1043A.2.16 Can’t initialize character set . . . . . . . . . . 1043A.2.17 File Not Found . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1044

    A.3 Installation-Related Issues . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1045A.3.1 Problems Linking to the MySQL Client Library

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1045A.3.2 How to Run MySQL as a Normal User . . . . . . . 1046A.3.3 Problems with File Permissions . . . . . . . . . . . . . . 1047

    A.4 Administration-Related Issues . . . . . . . . . . . . . . . . . . . . . . . . 1047A.4.1 How to Reset the Root Password . . . . . . . . . . . . . 1047A.4.2 What to Do If MySQL Keeps Crashing . . . . . . . 1049A.4.3 How MySQL Handles a Full Disk . . . . . . . . . . . . 1051A.4.4 Where MySQL Stores Temporary Files . . . . . . . 1052A.4.5 How to Protect or Change the MySQL Socket File

    ‘/tmp/mysql.sock’ . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1053A.4.6 Time Zone Problems . . . . . . . . . . . . . . . . . . . . . . . . 1053

    A.5 Query-Related Issues . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1054A.5.1 Case Sensitivity in Searches . . . . . . . . . . . . . . . . . . 1054A.5.2 Problems Using DATE Columns . . . . . . . . . . . . . . . 1054A.5.3 Problems with NULL Values . . . . . . . . . . . . . . . . . . 1055A.5.4 Problems with Column Aliases . . . . . . . . . . . . . . . 1056A.5.5 Rollback Failure for Non-Transactional Tables

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1057A.5.6 Deleting Rows from Related Tables . . . . . . . . . . . 1057A.5.7 Solving Problems with No Matching Rows . . . . 1058A.5.8 Problems with Floating-Point Comparisons . . . 1058

    A.6 Optimizer-Related Issues . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1061A.7 Table Definition-Related Issues . . . . . . . . . . . . . . . . . . . . . . . 1061

    A.7.1 Problems with ALTER TABLE . . . . . . . . . . . . . . . . . 1061A.7.2 How to Change the Order of Columns in a Table

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1062A.7.3 TEMPORARY TABLE Problems . . . . . . . . . . . . . . . . . . 1063

    Appendix B Credits . . . . . . . . . . . . . . . . . . . . . . 1064B.1 Developers at MySQL AB . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1064B.2 Contributors to MySQL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1067B.3 Documenters and translators . . . . . . . . . . . . . . . . . . . . . . . . . 1071B.4 Libraries used by and included with MySQL . . . . . . . . . . . 1072B.5 Packages that support MySQL . . . . . . . . . . . . . . . . . . . . . . . . 1073B.6 Tools that were used to create MySQL . . . . . . . . . . . . . . . . 1073B.7 Supporters of MySQL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1074

  • xxvi

    Appendix C MySQL Change History. . . . . . . 1075C.1 Changes in release 5.0.x (Development). . . . . . . . . . . . . . . . 1075

    C.1.1 Changes in release 5.0.1 (not released yet) . . . . 1075C.1.2 Changes in release 5.0.0 (22 Dec 2003: Alpha)

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1079C.2 Changes in release 4.1.x (Beta) . . . . . . . . . . . . . . . . . . . . . . . 1079

    C.2.1 Changes in release 4.1.4 (to be released soon) . . 1080C.2.2 Changes in release 4.1.3 (28 Jun 2004: Beta) . . 1080C.2.3 Changes in release 4.1.2 (28 May 2004) . . . . . . . 1083C.2.4 Changes in release 4.1.1 (01 Dec 2003) . . . . . . . . 1091C.2.5 Changes in release 4.1.0 (03 Apr 2003: Alpha)

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1096C.3 Changes in release 4.0.x (Production) . . . . . . . . . . . . . . . . . 1099

    C.3.1 Changes in release 4.0.21 (not released yet) . . . 1099C.3.2 Changes in release 4.0.20 (17 May 2004) . . . . . . 1100C.3.3 Changes in release 4.0.19 (04 May 2004) . . . . . . 1100C.3.4 Changes in release 4.0.18 (12 Feb 2004) . . . . . . . 1104C.3.5 Changes in release 4.0.17 (14 Dec 2003) . . . . . . . 1106C.3.6 Changes in release 4.0.16 (17 Oct 2003) . . . . . . . 1109C.3.7 Changes in release 4.0.15 (03 Sep 2003) . . . . . . . 1112C.3.8 Changes in release 4.0.14 (18 Jul 2003) . . . . . . . 1116C.3.9 Changes in release 4.0.13 (16 May 2003) . . . . . . 1119C.3.10 Changes in release 4.0.12 (15 Mar 2003:

    Production) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1123C.3.11 Changes in release 4.0.11 (20 Feb 2003) . . . . . . 1124C.3.12 Changes in release 4.0.10 (29 Jan 2003) . . . . . . 1125C.3.13 Changes in release 4.0.9 (09 Jan 2003) . . . . . . . 1127C.3.14 Changes in release 4.0.8 (07 Jan 2003) . . . . . . . 1127C.3.15 Changes in release 4.0.7 (20 Dec 2002) . . . . . . . 1128C.3.16 Changes in release 4.0.6 (14 Dec 2002: Gamma)

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1128C.3.17 Changes in release 4.0.5 (13 Nov 2002). . . . . . . 1130C.3.18 Changes in release 4.0.4 (29 Sep 2002) . . . . . . . 1132C.3.19 Changes in release 4.0.3 (26 Aug 2002: Beta)

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1133C.3.20 Changes in release 4.0.2 (01 Jul 2002) . . . . . . . 1135C.3.21 Changes in release 4.0.1 (23 Dec 2001) . . . . . . . 1139C.3.22 Changes in release 4.0.0 (Oct 2001: Alpha). . . 1140

    C.4 Changes in release 3.23.x (Recent; still supported). . . . . . 1141C.4.1 Changes in release 3.23.59 (not released yet) . . 1142C.4.2 Changes in release 3.23.58 (11 Sep 2003) . . . . . . 1143C.4.3 Changes in release 3.23.57 (06 Jun 2003) . . . . . . 1143C.4.4 Changes in release 3.23.56 (13 Mar 2003) . . . . . 1144C.4.5 Changes in release 3.23.55 (23 Jan 2003) . . . . . . 1145C.4.6 Changes in release 3.23.54 (05 Dec 2002) . . . . . . 1146C.4.7 Changes in release 3.23.53 (09 Oct 2002) . . . . . . 1147C.4.8 Changes in release 3.23.52 (14 Aug 2002) . . . . . 1147C.4.9 Changes in release 3.23.51 (31 May 2002) . . . . . 1148

  • xxvii

    C.4.10 Changes in release 3.23.50 (21 Apr 2002). . . . . 1149C.4.11 Changes in release 3.23.49 . . . . . . . . . . . . . . . . . . 1150C.4.12 Changes in release 3.23.48 (07 Feb 2002) . . . . . 1150C.4.13 Changes in release 3.23.47 (27 Dec 2001) . . . . . 1151C.4.14 Changes in release 3.23.46 (29 Nov 2001) . . . . 1151C.4.15 Changes in release 3.23.45 (22 Nov 2001) . . . . 1152C.4.16 Changes in release 3.23.44 (31 Oct 2001) . . . . . 1152C.4.17 Changes in release 3.23.43 (04 Oct 2001) . . . . . 1153C.4.18 Changes in release 3.23.42 (08 Sep 2001) . . . . . 1154C.4.19 Changes in release 3.23.41 (11 Aug 2001) . . . . 1154C.4.20 Changes in release 3.23.40 . . . . . . . . . . . . . . . . . . 1155C.4.21 Changes in release 3.23.39 (12 Jun 2001) . . . . . 1156C.4.22 Changes in release 3.23.38 (09 May 2001) . . . . 1156C.4.23 Changes in release 3.23.37 (17 Apr 2001). . . . . 1157C.4.24 Changes in release 3.23.36 (27 Mar 2001) . . . . 1158C.4.25 Changes in release 3.23.35 (15 Mar 2001) . . . . 1158C.4.26 Changes in release 3.23.34a . . . . . . . . . . . . . . . . . 1158C.4.27 Changes in release 3.23.34 (10 Mar 2001) . . . . 1158C.4.28 Changes in release 3.23.33 (09 Feb 2001) . . . . . 1159C.4.29 Changes in release 3.23.32 (22 Jan 2001:

    Production) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1161C.4.30 Changes in release 3.23.31 (17 Jan 2001) . . . . . 1161C.4.31 Changes in release 3.23.30 (04 Jan 2001) . . . . . 1162C.4.32 Changes in release 3.23.29 (16 Dec 2000) . . . . . 1163C.4.33 Changes in release 3.23.28 (22 Nov 2000: Gamma)

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1164C.4.34 Changes in release 3.23.27 (24 Oct 2000) . . . . . 1166C.4.35 Changes in release 3.23.26 (18 Oct 2000) . . . . . 1166C.4.36 Changes in release 3.23.25 (29 Sep 2000) . . . . . 1167C.4.37 Changes in release 3.23.24 (08 Sep 2000) . . . . . 1168C.4.38 Changes in release 3.23.23 (01 Sep 2000) . . . . . 1168C.4.39 Changes in release 3.23.22 (31 Jul 2000) . . . . . 1170C.4.40 Changes in release 3.23.21 . . . . . . . . . . . . . . . . . . 1170C.4.41 Changes in release 3.23.20 . . . . . . . . . . . . . . . . . . 1171C.4.42 Changes in release 3.23.19 . . . . . . . . . . . . . . . . . . 1171C.4.43 Changes in release 3.23.18 . . . . . . . . . . . . . . . . . . 1171C.4.44 Changes in release 3.23.17 . . . . . . . . . . . . . . . . . . 1172C.4.45 Changes in release 3.23.16 . . . . . . . . . . . . . . . . . . 1172C.4.46 Changes in release 3.23.15 (May 2000: Beta)

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1173C.4.47 Changes in release 3.23.14 . . . . . . . . . . . . . . . . . . 1174C.4.48 Changes in release 3.23.13 . . . . . . . . . . . . . . . . . . 1174C.4.49 Changes in release 3.23.12 (07 Mar 2000) . . . . 1175C.4.50 Changes in release 3.23.11 . . . . . . . . . . . . . . . . . . 1175C.4.51 Changes in release 3.23.10 . . . . . . . . . . . . . . . . . . 1176C.4.52 Changes in release 3.23.9 . . . . . . . . . . . . . . . . . . . 1176C.4.53 Changes in release 3.23.8 (02 Jan 2000) . . . . . . 1177C.4.54 Changes in release 3.23.7 (10 Dec 1999) . . . . . . 1177

  • xxviii

    C.4.55 Changes in release 3.23.6 . . . . . . . . . . . . . . . . . . . 1178C.4.56 Changes in release 3.23.5 (20 Oct 1999) . . . . . . 1179C.4.57 Changes in release 3.23.4 (28 Sep 1999) . . . . . . 1180C.4.58 Changes in release 3.23.3 . . . . . . . . . . . . . . . . . . . 1180C.4.59 Changes in release 3.23.2 (09 Aug 1999) . . . . . 1181C.4.60 Changes in release 3.23.1 . . . . . . . . . . . . . . . . . . . 1182C.4.61 Changes in release 3.23.0 (05 Aug 1999: Alpha)

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1182C.5 Changes in release 3.22.x (Old; discontinued) . . . . . . . . . . 1184

    C.5.1 Changes in release 3.22.35 . . . . . . . . . . . . . . . . . . . 1184C.5.2 Changes in release 3.22.34 . . . . . . . . . . . . . . . . . . . 1184C.5.3 Changes in release 3.22.33 . . . . . . . . . . . . . . . . . . . 1184C.5.4 Changes in release 3.22.32 (14 Feb 2000) . . . . . . 1184C.5.5 Changes in release 3.22.31 . . . . . . . . . . . . . . . . . . . 1184C.5.6 Changes in release 3.22.30 . . . . . . . . . . . . . . . . . . . 1184C.5.7 Changes in release 3.22.29 (02 Jan 2000) . . . . . . 1185C.5.8 Changes in release 3.22.28 (20 Oct 1999) . . . . . . 1185C.5.9 Changes in release 3.22.27 . . . . . . . . . . . . . . . . . . . 1185C.5.10 Changes in release 3.22.26 (16 Sep 1999) . . . . . 1185C.5.11 Changes in release 3.22.25 . . . . . . . . . . . . . . . . . . 1186C.5.12 Changes in release 3.22.24 (05 Jul 1999) . . . . . 1186C.5.13 Changes in release 3.22.23 (08 Jun 1999) . . . . . 1186C.5.14 Changes in release 3.22.22 (30 Apr 1999). . . . . 1186C.5.15 Changes in release 3.22.21 . . . . . . . . . . . . . . . . . . 1187C.5.16 Changes in release 3.22.20 (18 Mar 1999) . . . . 1187C.5.17 Changes in release 3.22.19 (Mar 1999: Production)

    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1187C.5.18 Changes in release 3.2