Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
e8343852
Commit
e8343852
authored
Dec 24, 2001
by
unknown
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fixups in line with MySQL trademark policy; chapter 1.
parent
e626e9ae
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
368 additions
and
355 deletions
+368
-355
Docs/manual.texi
Docs/manual.texi
+368
-355
No files found.
Docs/manual.texi
View file @
e8343852
...
@@ -108,10 +108,10 @@ END-INFO-DIR-ENTRY
...
@@ -108,10 +108,10 @@ END-INFO-DIR-ENTRY
@node Top, Introduction, (dir), (dir)
@node Top, Introduction, (dir), (dir)
@ifinfo
@ifinfo
This is a manual for
MySQL. This version is about the
This is a manual for
the MySQL Database System.
@value{mysql_version} version of MySQL. You can find a manual
This version is about the @value{mysql_version} version of MySQL Server.
about any older version of MySQL in the binary or source
You can find a specific manual for any older version of MySQL Server
distribution for that version.
in the binary or source
distribution for that version.
@end ifinfo
@end ifinfo
@menu
@menu
...
@@ -144,38 +144,40 @@ distribution for that version.
...
@@ -144,38 +144,40 @@ distribution for that version.
@cindex overview
@cindex overview
@cindex general information
@cindex general information
@code{MySQL (TM)} is a very fast, multi-threaded, multi-user, and robust
The @code{MySQL (TM)} software delivers a very fast, multi-threaded,
@code{SQL} (@code{Structured Query Language}) database server.
multi-user, and robust @code{SQL} (@code{Structured Query Language})
MySQL is intended for mission-critical, heavy load production systems
database server.
as well as for embedding into mass-deployed software.
MySQL Server is intended for mission-critical, heavy load production
systems as well as for embedding into mass-deployed software.
@code{MySQL} is a trademark of @code{MySQL AB}.
@code{MySQL} is a trademark of @code{MySQL AB}.
MySQL has @code{Dual licensing}, you can use MySQL free of charge
The MySQL software has @code{Dual licensing}, you can use MySQL Server
under the @code{GNU GENERAL PUBLIC LICENSE}
free of charge
under the @code{GNU GENERAL PUBLIC LICENSE}
(@uref{http://www.gnu.org/licenses/}).
(@uref{http://www.gnu.org/licenses/}).
You can also purchase commercial MySQL
licenses from @code{MySQL AB}
You can also purchase commercial MySQL
Server licenses from
if you do not wish to be bound by the terms of the GPL.
@code{MySQL AB}
if you do not wish to be bound by the terms of the GPL.
@xref{Licensing and Support}.
@xref{Licensing and Support}.
The MySQL web site (@uref{http://www.mysql.com/}) provides the latest
The MySQL web site (@uref{http://www.mysql.com/}) provides the latest
information about
MySQL
.
information about
the MySQL software
.
The following list describes some useful sections of the manual:
The following list describes some useful sections of the manual:
@itemize @bullet
@itemize @bullet
@item
@item
For information about the company behind
MySQL, see
For information about the company behind
the MySQL Database Server,
@ref{What is MySQL AB}.
see
@ref{What is MySQL AB}.
@item
@item
For a discussion of MySQL's capabilities, see @ref{Features}.
For a discussion about the capabilities of the MySQL Database Server,
see @ref{Features}.
@item
@item
For installation instructions, see @ref{Installing}.
For installation instructions, see @ref{Installing}.
@item
@item
For tips on porting
MySQL to new architectures or operating
For tips on porting
the MySQL Database Software to new architectures
systems, see @ref{Porting}.
or operating
systems, see @ref{Porting}.
@item
@item
For information about upgrading from a Version 3.23 release, see
For information about upgrading from a Version 3.23 release, see
...
@@ -186,7 +188,8 @@ For information about upgrading from a Version 3.22 release, see
...
@@ -186,7 +188,8 @@ For information about upgrading from a Version 3.22 release, see
@ref{Upgrading-from-3.22}.
@ref{Upgrading-from-3.22}.
@item
@item
For a tutorial introduction to MySQL, see @ref{Tutorial}.
For a tutorial introduction to the MySQL Database Server,
see @ref{Tutorial}.
@item
@item
For examples of SQL and benchmarking information, see the benchmarking
For examples of SQL and benchmarking information, see the benchmarking
...
@@ -215,7 +218,7 @@ The @code{mysqlbug} script should be used to generate bug reports.
...
@@ -215,7 +218,7 @@ The @code{mysqlbug} script should be used to generate bug reports.
For source distributions, the @code{mysqlbug} script can be found in the
For source distributions, the @code{mysqlbug} script can be found in the
@file{scripts} directory. For binary distributions, @code{mysqlbug} can
@file{scripts} directory. For binary distributions, @code{mysqlbug} can
be found in the @file{bin} directory. If you have found a sensitive
be found in the @file{bin} directory. If you have found a sensitive
security bug in MySQL, you should send an e-mail to
security bug in MySQL
Server
, you should send an e-mail to
@email{security@@mysql.com}.
@email{security@@mysql.com}.
@cindex errors, reporting
@cindex errors, reporting
...
@@ -247,7 +250,8 @@ This is the MySQL reference manual; it documents MySQL Version
...
@@ -247,7 +250,8 @@ This is the MySQL reference manual; it documents MySQL Version
@value{mysql_version}. Being a reference manual, it does not provide
@value{mysql_version}. Being a reference manual, it does not provide
general instruction on SQL or relational database concepts.
general instruction on SQL or relational database concepts.
As MySQL is work in progress, the manual gets updated frequently.
As the MySQL Database Software is work in progress, the manual gets
updated frequently.
The most recent version of this manual is available at
The most recent version of this manual is available at
@uref{http://www.mysql.com/documentation/} in many different formats,
@uref{http://www.mysql.com/documentation/} in many different formats,
currently there are Texinfo, plain text, Info, HTML, PostScript, and
currently there are Texinfo, plain text, Info, HTML, PostScript, and
...
@@ -417,7 +421,7 @@ that builds its business providing services around the MySQL database.
...
@@ -417,7 +421,7 @@ that builds its business providing services around the MySQL database.
@xref{What is MySQL AB}.
@xref{What is MySQL AB}.
The MySQL web site (@uref{http://www.mysql.com/})
The MySQL web site (@uref{http://www.mysql.com/})
provides the latest information about MySQL and MySQL AB.
provides the latest information about MySQL
software
and MySQL AB.
@table @asis
@table @asis
...
@@ -427,7 +431,7 @@ A database is a structured collection of data. It may be anything from a
...
@@ -427,7 +431,7 @@ A database is a structured collection of data. It may be anything from a
simple shopping list to a picture gallery or the vast amounts of
simple shopping list to a picture gallery or the vast amounts of
information in a corporate network. To add, access, and process data
information in a corporate network. To add, access, and process data
stored in a computer database, you need a database management system
stored in a computer database, you need a database management system
such as MySQL. Since computers are very good at handling large
such as MySQL
Server
. Since computers are very good at handling large
amounts of data, database management plays a central role in computing,
amounts of data, database management plays a central role in computing,
as stand-alone utilities, or as parts of other applications.
as stand-alone utilities, or as parts of other applications.
...
@@ -436,60 +440,62 @@ as stand-alone utilities, or as parts of other applications.
...
@@ -436,60 +440,62 @@ as stand-alone utilities, or as parts of other applications.
@item MySQL is a relational database management system.
@item MySQL is a relational database management system.
A relational database stores data in separate tables rather than putting
A relational database stores data in separate tables rather than putting
all the data in one big storeroom. This adds speed and flexibility.
The
all the data in one big storeroom. This adds speed and flexibility.
tables are linked by defined relations making it possible to combine
The
tables are linked by defined relations making it possible to combine
data from several tables on request.
The SQL part of MySQL
data from several tables on request.
The @code{SQL} part of
stands for "Structured Query Language" - the most common standardised
``@code{MySQL}'' stands for ``@code{Structured Query Language}''
language used to access databases.
- the most common standardised
language used to access databases.
@cindex relational databases, defined
@cindex relational databases, defined
@cindex SQL, defined
@cindex SQL, defined
@item MySQL
is Open Source Softwar
e.
@item MySQL
Software is Open Sourc
e.
Open Source means that it is possible for anyone to use and modify.
Open Source means that it is possible for anyone to use and modify.
Anybody can download
MySQL
from the Internet and use it
Anybody can download
the MySQL software
from the Internet and use it
without paying anything. Anybody so inclined can study the source code
without paying anything. Anybody so inclined can study the source code
and change it to fit their needs.
MySQL
uses the GPL (GNU
and change it to fit their needs.
The MySQL software
uses the GPL (GNU
General Public License) @uref{http://www.gnu.org/licenses/}, to define what you
General Public License) @uref{http://www.gnu.org/licenses/}, to define what you
may and may not do with the software in different situations. If you
may and may not do with the software in different situations. If you
feel uncomfortable with the GPL or need to embed MySQL into a commercial
feel uncomfortable with the GPL or need to embed MySQL
code
into a commercial
application you can buy a commercially licensed version from us.
application you can buy a commercially licensed version from us.
@xref{MySQL server licenses}.
@xref{MySQL server licenses}.
@cindex Open Source, defined
@cindex Open Source, defined
@cindex General Public License
@cindex General Public License
@item Why use
MySQL
?
@item Why use
the MySQL Database Server
?
MySQL is very fast, reliable, and easy to use. If that is what
The MySQL Database Server is very fast, reliable, and easy to use.
you are looking for, you should give it a try. MySQL also has a
If that is what you are looking for, you should give it a try.
MySQL Server also has a
practical set of features developed in close cooperation with
practical set of features developed in close cooperation with
our users. You can find a performance comparison of MySQL
our users. You can find a performance comparison of MySQL
Server
to some other database managers on our benchmark page.
to some other database managers on our benchmark page.
@xref{MySQL Benchmarks}.
@xref{MySQL Benchmarks}.
MySQL was originally developed to handle large databases
MySQL
Server
was originally developed to handle large databases
much faster than existing solutions and has been successfully used in
much faster than existing solutions and has been successfully used in
highly demanding production environments for several years. Though
highly demanding production environments for several years. Though
under constant development, MySQL today offers a rich and
under constant development, MySQL
Server
today offers a rich and
useful set of functions. The connectivity, speed, and security make
useful set of functions. The connectivity, speed, and security make
MySQL highly suited for accessing databases on the Internet.
MySQL
Server
highly suited for accessing databases on the Internet.
@item The technical features of MySQL
@item The technical features of MySQL
Server
For advanced technical information, see @ref{Reference}. MySQL is
For advanced technical information, see @ref{Reference}. The MySQL
a client/server system that consists of a multi-threaded SQL server
Database Software is a client/server system that consists of a
that supports different backends, several different client programs and
multi-threaded SQL server that supports different backends, several
libraries, administrative tools, and several programming interfaces.
different client programs and libraries, administrative tools, and
several programming interfaces.
We also provide MySQL as a multi-threaded library which you can
We also provide MySQL
Server
as a multi-threaded library which you can
link into your application to get a smaller, faster, easier to manage
link into your application to get a smaller, faster, easier to manage
product.
product.
@item
MySQL has a lot of contributed
software available.
@item
There is a lot of contributed MySQL
software available.
It is very likely that you will find that your favorite application or
It is very likely that you will find that your favorite application or
language already supports
MySQL
.
language already supports
the MySQL Database Server
.
@end table
@end table
...
@@ -524,7 +530,7 @@ flexible enough for our needs. This resulted in a new SQL interface to our
...
@@ -524,7 +530,7 @@ flexible enough for our needs. This resulted in a new SQL interface to our
database but with almost the same API interface as @code{mSQL}. This API was
database but with almost the same API interface as @code{mSQL}. This API was
chosen to ease porting of third-party code.
chosen to ease porting of third-party code.
The derivation of the name
MySQL
is not perfectly clear. Our base
The derivation of the name
@code{MySQL}
is not perfectly clear. Our base
directory and a large number of our libraries and tools have had the prefix
directory and a large number of our libraries and tools have had the prefix
``my'' for well over 10 years. However, Monty's daughter (some years younger)
``my'' for well over 10 years. However, Monty's daughter (some years younger)
is also named My. Which of the two gave its name to MySQL is
is also named My. Which of the two gave its name to MySQL is
...
@@ -538,7 +544,7 @@ still a mystery, even for us.
...
@@ -538,7 +544,7 @@ still a mystery, even for us.
@cindex features of MySQL
@cindex features of MySQL
The following list describes some of the important characteristics
The following list describes some of the important characteristics
of
MySQL
. @xref{MySQL 4.0 In A Nutshell}.
of
the MySQL Database Software
. @xref{MySQL 4.0 In A Nutshell}.
@c This list is too technical and should be divided into one feature
@c This list is too technical and should be divided into one feature
@c list comparable to commercial competition and a very technical on
@c list comparable to commercial competition and a very technical on
...
@@ -549,7 +555,7 @@ of MySQL. @xref{MySQL 4.0 In A Nutshell}.
...
@@ -549,7 +555,7 @@ of MySQL. @xref{MySQL 4.0 In A Nutshell}.
@item
@item
Written in C and C++. Tested with a broad range of different compilers.
Written in C and C++. Tested with a broad range of different compilers.
@item
@item
No memory leaks.
MySQL
has been tested with Purify, a commercial
No memory leaks.
The MySQL code
has been tested with Purify, a commercial
memory leakage detector.
memory leakage detector.
@item
@item
Works on many different platforms. @xref{Which OS}.
Works on many different platforms. @xref{Which OS}.
...
@@ -643,13 +649,13 @@ password traffic is encrypted when you connect to a server.
...
@@ -643,13 +649,13 @@ password traffic is encrypted when you connect to a server.
@item Scalability and Limits
@item Scalability and Limits
@itemize @bullet
@itemize @bullet
@item
@item
Handles large databases. We are using MySQL with some
Handles large databases. We are using MySQL
Server
with some
databases that contain 50,000,000 records and we know of users that
databases that contain 50,000,000 records and we know of users that
uses MySQL with 60,000 tables and about 5,000,000,000 rows.
uses MySQL
Server
with 60,000 tables and about 5,000,000,000 rows.
@item
@item
Up to 32 indexes per table are allowed. Each index may consist of 1 to 16
Up to 32 indexes per table are allowed. Each index may consist of 1 to 16
columns or parts of columns. The maximum index width is 500 bytes
columns or parts of columns. The maximum index width is 500 bytes
(this may be changed when compiling MySQL). An index may use a prefix
(this may be changed when compiling MySQL
Server
). An index may use a prefix
of a @code{CHAR} or @code{VARCHAR} field.
of a @code{CHAR} or @code{VARCHAR} field.
@end itemize
@end itemize
...
@@ -681,7 +687,7 @@ string columns are case insensitive.
...
@@ -681,7 +687,7 @@ string columns are case insensitive.
Sorting is done according to the chosen character set (the Swedish
Sorting is done according to the chosen character set (the Swedish
way by default). It is possible to change this when the MySQL server
way by default). It is possible to change this when the MySQL server
is started up. To see an example of very advanced sorting, look at the
is started up. To see an example of very advanced sorting, look at the
Czech sorting code. MySQL supports many different character sets
Czech sorting code. MySQL
Server
supports many different character sets
that can be specified at compile and run time.
that can be specified at compile and run time.
@end itemize
@end itemize
...
@@ -714,26 +720,27 @@ very active in identifying problems as well as reporting types of use.
...
@@ -714,26 +720,27 @@ very active in identifying problems as well as reporting types of use.
Original code stems back from the early 80s, providing a stable code
Original code stems back from the early 80s, providing a stable code
base, and the ISAM table format remains backwards compatible.
base, and the ISAM table format remains backwards compatible.
At TcX, the predecessor of MySQL AB, MySQL has worked in projects
At TcX, the predecessor of MySQL AB, MySQL
code
has worked in projects
since mid-1996, without any problems.
since mid-1996, without any problems.
When MySQL was released to a wider public, we noticed that there were
When the MySQL Database Software was released to a wider public,
we noticed that there were
some pieces of ``untested code'' that were quickly found by the new
some pieces of ``untested code'' that were quickly found by the new
users who made different types of queries from us. Each new release
users who made different types of queries from us. Each new release
has had fewer portability problems (even though each new release has
has had fewer portability problems (even though each new release has
had many new features).
had many new features).
Each release of
MySQL
has been usable. There have only been problems
Each release of
the MySQL Server
has been usable. There have only been problems
when users try code from the ``gray zones.'' Naturally, new users
when users try code from the ``gray zones.'' Naturally, new users
don't know what the gray zones are; this section attempts to indicate
don't know what the gray zones are; this section attempts to indicate
those that are currently known.
those that are currently known.
The descriptions mostly deal with Version 3.23 of MySQL.
The descriptions mostly deal with Version 3.23 of MySQL
Server
.
All known and reported bugs are fixed in the latest version, with the
All known and reported bugs are fixed in the latest version, with the
exception of those listed in the bugs section, which are things that
exception of those listed in the bugs section, which are things that
are design-related. @xref{Bugs}.
are design-related. @xref{Bugs}.
MySQL design is multi-layered with independent modules. Some of the
The MySQL Server design is multi-layered with independent modules.
newer modules are listed below with an indication of how well-tested
Some of the newer modules are listed below with an indication of how
each of them is:
well-tested
each of them is:
@cindex modules, list of
@cindex modules, list of
...
@@ -750,7 +757,7 @@ used in some large, heavy load production systems.
...
@@ -750,7 +757,7 @@ used in some large, heavy load production systems.
@item @code{BDB} tables -- Gamma
@item @code{BDB} tables -- Gamma
The @code{Berkeley DB} code is very stable, but we are still improving
The @code{Berkeley DB} code is very stable, but we are still improving
the @code{BDB} transactional table handler interface in MySQL, so it
the @code{BDB} transactional table handler interface in MySQL
Server
, so it
will take some time before this is as well tested as the other table
will take some time before this is as well tested as the other table
types.
types.
...
@@ -817,7 +824,7 @@ On Linux 2.2 you can get bigger tables than 2G by using the LFS patch for
...
@@ -817,7 +824,7 @@ On Linux 2.2 you can get bigger tables than 2G by using the LFS patch for
the ext2 file system. On Linux 2.4 there exists also patches for ReiserFS
the ext2 file system. On Linux 2.4 there exists also patches for ReiserFS
to get support for big files.
to get support for big files.
This means that the table size for MySQL is normally limited by
This means that the table size for MySQL
databases
is normally limited by
the operating system.
the operating system.
By default, MySQL tables have a maximum size of about 4G. You can
By default, MySQL tables have a maximum size of about 4G. You can
...
@@ -851,14 +858,14 @@ tables}.
...
@@ -851,14 +858,14 @@ tables}.
@cindex compliance, Y2K
@cindex compliance, Y2K
@cindex date functions, Y2K compliance
@cindex date functions, Y2K compliance
MySQL
itself has no problems with Year 2000 (Y2K) compliance:
The MySQL Server
itself has no problems with Year 2000 (Y2K) compliance:
@itemize @bullet
@itemize @bullet
@item
@item
MySQL uses Unix time functions and has no problems with dates
MySQL
Server
uses Unix time functions and has no problems with dates
until @code{2069}; all 2-digit years are regarded to be in the range
until @code{2069}; all 2-digit years are regarded to be in the range
@code{1970} to @code{2069}, which means that if you store @code{01} in a
@code{1970} to @code{2069}, which means that if you store @code{01} in a
@code{year} column, MySQL treats it as @code{2001}.
@code{year} column, MySQL
Server
treats it as @code{2001}.
@item
@item
All MySQL date functions are stored in one file @file{sql/time.cc}
All MySQL date functions are stored in one file @file{sql/time.cc}
...
@@ -870,7 +877,7 @@ can store years @code{0} and @code{1901} to @code{2155} in 1 byte and display
...
@@ -870,7 +877,7 @@ can store years @code{0} and @code{1901} to @code{2155} in 1 byte and display
them using 2 or 4 digits.
them using 2 or 4 digits.
@end itemize
@end itemize
You may run into problems with applications that use MySQL in a
You may run into problems with applications that use MySQL
Server
in a
way that is not Y2K-safe. For example, many old applications store
way that is not Y2K-safe. For example, many old applications store
or manipulate years using 2-digit values (which are ambiguous) rather than
or manipulate years using 2-digit values (which are ambiguous) rather than
4-digit values. This problem may be compounded by applications that use
4-digit values. This problem may be compounded by applications that use
...
@@ -880,7 +887,7 @@ Unfortunately, these problems may be difficult to fix, because different
...
@@ -880,7 +887,7 @@ Unfortunately, these problems may be difficult to fix, because different
applications may be written by different programmers, each of whom may
applications may be written by different programmers, each of whom may
use a different set of conventions and date-handling functions.
use a different set of conventions and date-handling functions.
Here is a simple demonstration illustrating that MySQL doesn't have
Here is a simple demonstration illustrating that MySQL
Server
doesn't have
any problems with dates until the year 2030:
any problems with dates until the year 2030:
@example
@example
...
@@ -940,8 +947,8 @@ range up to only @code{2030-01-01}. @code{TIMESTAMP} has a range of
...
@@ -940,8 +947,8 @@ range up to only @code{2030-01-01}. @code{TIMESTAMP} has a range of
@code{1970} to @code{2030} on 32-bit machines (signed value). On 64-bit
@code{1970} to @code{2030} on 32-bit machines (signed value). On 64-bit
machines it handles times up to @code{2106} (unsigned value).
machines it handles times up to @code{2106} (unsigned value).
Even though MySQL is Y2K-compliant, it is your responsibility to
Even though MySQL
Server
is Y2K-compliant, it is your responsibility to
provide unambiguous input. See @ref{Y2K issues} for MySQL's rules
provide unambiguous input. See @ref{Y2K issues} for MySQL
Server
's rules
for dealing with ambiguous date input data (data containing 2-digit year
for dealing with ambiguous date input data (data containing 2-digit year
values).
values).
...
@@ -961,9 +968,9 @@ We are a virtual organisation with people in a dozen countries around
...
@@ -961,9 +968,9 @@ We are a virtual organisation with people in a dozen countries around
the world. We communicate extensively over the net every day with each
the world. We communicate extensively over the net every day with each
other and with our users, supporters and partners.
other and with our users, supporters and partners.
We are dedicated to developing
MySQL and spreading our database to new
We are dedicated to developing
the MySQL software and spreading our
users. MySQL AB owns the copyright to the MySQL source code, the MySQL
database to new users. MySQL AB owns the copyright to the MySQL source
logo and trademark and this manual. @xref{What-is}.
code, the MySQL
logo and trademark and this manual. @xref{What-is}.
@menu
@menu
* MySQL AB business model and services:: The Business Model and Services of MySQL AB
* MySQL AB business model and services:: The Business Model and Services of MySQL AB
...
@@ -972,7 +979,7 @@ logo and trademark and this manual. @xref{What-is}.
...
@@ -972,7 +979,7 @@ logo and trademark and this manual. @xref{What-is}.
The MySQL core values show our dedication to MySQL and Open Source.
The MySQL core values show our dedication to MySQL and Open Source.
We want
MySQL
to be:
We want
the MySQL Database Software
to be:
@itemize @bullet
@itemize @bullet
@item
@item
The best and the most widely used database in the world.
The best and the most widely used database in the world.
...
@@ -1095,22 +1102,22 @@ Program, please e-mail @email{certification@@mysql.com}.
...
@@ -1095,22 +1102,22 @@ Program, please e-mail @email{certification@@mysql.com}.
@node Business Services Consulting, Business Services Commercial licenses, Business Services Training, MySQL AB business model and services
@node Business Services Consulting, Business Services Commercial licenses, Business Services Training, MySQL AB business model and services
@subsubsection Consulting
@subsubsection Consulting
MySQL AB and its Authorised Partners offer consulting services to
MySQL AB and its Authorised Partners offer consulting services to
users of
MySQL and to those who embed MySQL in their own software,
users of
the MySQL Server and to those who embed the MySQL Server
all over the world.
in their own software,
all over the world.
Our consultants can help you design and tune your databases, construct
Our consultants can help you design and tune your databases, construct
efficient queries, tune your platform for optimal performance, resolve
efficient queries, tune your platform for optimal performance, resolve
migration issues, set up replication, build robust transactional
migration issues, set up replication, build robust transactional
applications, and more.
applications, and more.
We also help customers embed
MySQL in their products and applications
We also help customers embed
the MySQL Server in their products and
for large-scale deployment.
applications
for large-scale deployment.
Our consultants work in close collaboration with our development team
Our consultants work in close collaboration with our development team
which ensures the technical quality of our professional services.
which ensures the technical quality of our professional services.
Consulting assignments range from 2-day power start sessions to
Consulting assignments range from 2-day power start sessions to
projects that span weeks and months. Our expertise does not only cover
projects that span weeks and months. Our expertise does not only cover
MySQL
, but extends into programming and scripting languages such a
s
MySQL
Server, but extends into programming and scripting language
s
PHP, Perl and more.
such as
PHP, Perl and more.
If you are interested in our consulting services or want to become a
If you are interested in our consulting services or want to become a
consulting partner, please visit the consulting section of our web site
consulting partner, please visit the consulting section of our web site
...
@@ -1122,10 +1129,10 @@ consulting staff at @email{consulting@@mysql.com}.
...
@@ -1122,10 +1129,10 @@ consulting staff at @email{consulting@@mysql.com}.
@node Business Services Commercial licenses, Business Services Partnering, Business Services Consulting, MySQL AB business model and services
@node Business Services Commercial licenses, Business Services Partnering, Business Services Consulting, MySQL AB business model and services
@subsubsection Commercial Licenses
@subsubsection Commercial Licenses
The MySQL database is released under the @code{GNU General Public License}
The MySQL database is released under the @code{GNU General Public License}
(@code{GPL}). This means that
MySQL can be used free of charge under th
e
(@code{GPL}). This means that
the MySQL software can be used free of charg
e
GPL. If you do not want to be bound by the GPL terms (like the requirement
under the GPL. If you do not want to be bound by the GPL terms (like the
that your own application becomes GPL as well), you may purchase a
requirement that your own application becomes GPL as well), you may purchase
commercial license for the same product from MySQL AB at
a
commercial license for the same product from MySQL AB at
@uref{https://order.mysql.com/}.
@uref{https://order.mysql.com/}.
Since MySQL AB owns the copyright to the MySQL server, we are able to
Since MySQL AB owns the copyright to the MySQL server, we are able to
employ @code{Dual Licensing} which means that the same product is
employ @code{Dual Licensing} which means that the same product is
...
@@ -1135,14 +1142,14 @@ For details about when a commercial license is required, please see
...
@@ -1135,14 +1142,14 @@ For details about when a commercial license is required, please see
@ref{MySQL server licenses}.
@ref{MySQL server licenses}.
We also sell commercial licenses of third-party Open Source GPL software
We also sell commercial licenses of third-party Open Source GPL software
that adds value to
MySQL
. A good example is the @code{InnoDB}
that adds value to
the MySQL Server
. A good example is the @code{InnoDB}
transactional table handler that offers ACID support, row-level locking,
transactional table handler that offers ACID support, row-level locking,
crash recovery, multiversioning, foreign key support, and more.
crash recovery, multiversioning, foreign key support, and more.
@node Business Services Partnering, Business Services Advertising, Business Services Commercial licenses, MySQL AB business model and services
@node Business Services Partnering, Business Services Advertising, Business Services Commercial licenses, MySQL AB business model and services
@subsubsection Partnering
@subsubsection Partnering
@cindex partnering with MySQL
@cindex partnering with MySQL
AB
MySQL AB has a worldwide partner program that covers training courses,
MySQL AB has a worldwide partner program that covers training courses,
support, consulting, solutions, publications plus reselling and
support, consulting, solutions, publications plus reselling and
distributing MySQL and related products. Partners get visibility on the
distributing MySQL and related products. Partners get visibility on the
...
@@ -1193,8 +1200,8 @@ For press service and inquiries not covered in our News releases
...
@@ -1193,8 +1200,8 @@ For press service and inquiries not covered in our News releases
@email{press@@mysql.com}.
@email{press@@mysql.com}.
If you have a valid support contract with MySQL AB; you will get
If you have a valid support contract with MySQL AB; you will get
timely, precise answers to your technical questions about
MySQL.
timely, precise answers to your technical questions about
the MySQL
For more information, see @ref{Support}.
software.
For more information, see @ref{Support}.
You can order your support contract at
You can order your support contract at
@uref{https://order.mysql.com/}, or send an email to
@uref{https://order.mysql.com/}, or send an email to
@email{sales@@mysql.com}.
@email{sales@@mysql.com}.
...
@@ -1254,7 +1261,7 @@ attention to the appropriate mailing list.
...
@@ -1254,7 +1261,7 @@ attention to the appropriate mailing list.
Reports of errors (often called bugs), as well as questions and
Reports of errors (often called bugs), as well as questions and
comments, should be sent to the mailing list at
comments, should be sent to the mailing list at
@email{mysql@@lists.mysql.com}. If you have found a sensitive
@email{mysql@@lists.mysql.com}. If you have found a sensitive
security bug in
MySQL
, you should send an e-mail to
security bug in
the MySQL Server
, you should send an e-mail to
@email{security@@mysql.com}.
@email{security@@mysql.com}.
@xref{Bug reports}.
@xref{Bug reports}.
...
@@ -1311,13 +1318,13 @@ unique problems direct from the software engineers who code the MySQL
...
@@ -1311,13 +1318,13 @@ unique problems direct from the software engineers who code the MySQL
database engine.
database engine.
We try to take a broad and inclusive view of technical support. Almost
We try to take a broad and inclusive view of technical support. Almost
any problem involving MySQL is important to us if it's important to you.
any problem involving MySQL
software
is important to us if it's important to you.
Typically customers seek help on how to get different commands and
Typically customers seek help on how to get different commands and
utilities to work, remove performance bottlenecks, restore crashed
utilities to work, remove performance bottlenecks, restore crashed
systems, understand operating system or networking impacts on MySQL,
systems, understand operating system or networking impacts on MySQL,
set-up best practices for backup and recovery, utilise APIs, etc.
set-up best practices for backup and recovery, utilise APIs, etc.
Our support covers only the MySQL server and our own utilities, not
Our support covers only the MySQL server and our own utilities, not
third-party products that access
MySQL
, though we try to help with
third-party products that access
the MySQL server
, though we try to help with
these where we can.
these where we can.
Detailed information about our various support options is given at
Detailed information about our various support options is given at
...
@@ -1328,7 +1335,7 @@ our sales staff at @email{sales@@mysql.com}.
...
@@ -1328,7 +1335,7 @@ our sales staff at @email{sales@@mysql.com}.
Technical support is like life insurance. You can live happily
Technical support is like life insurance. You can live happily
without it for years, but when your hour arrives it becomes
without it for years, but when your hour arrives it becomes
critically important, yet it's too late to buy it!
critically important, yet it's too late to buy it!
If you use MySQL for important applications and encounter sudden
If you use MySQL
Server
for important applications and encounter sudden
troubles, it might take too long to figure out all the answers
troubles, it might take too long to figure out all the answers
yourself. You may need immediate access to the most experienced
yourself. You may need immediate access to the most experienced
MySQL troubleshooters available, those employed by MySQL AB.
MySQL troubleshooters available, those employed by MySQL AB.
...
@@ -1456,7 +1463,7 @@ code.
...
@@ -1456,7 +1463,7 @@ code.
@item
@item
When you distribute a non-GPL application that ONLY works with the MySQL
When you distribute a non-GPL application that ONLY works with the MySQL
server and ship
s it with MySQL
. This type of solution is actually
server and ship
it with the MySQL server
. This type of solution is actually
considered to be linking even if it's done over a network.
considered to be linking even if it's done over a network.
@item
@item
...
@@ -1467,7 +1474,7 @@ source code as required under the GPL license.
...
@@ -1467,7 +1474,7 @@ source code as required under the GPL license.
When you want to support the further development of the MySQL database
When you want to support the further development of the MySQL database
even if you don't formally need a commercial license. Purchasing support
even if you don't formally need a commercial license. Purchasing support
directly from MySQL AB is another good way of contributing to the
directly from MySQL AB is another good way of contributing to the
development of
MySQL
, with immediate advantages for you.
development of
the MySQL software
, with immediate advantages for you.
@xref{Support}.
@xref{Support}.
@end itemize
@end itemize
...
@@ -1497,7 +1504,7 @@ resulting product under GPL.
...
@@ -1497,7 +1504,7 @@ resulting product under GPL.
@item
@item
When you distribute the MySQL server source code bundled with other
When you distribute the MySQL server source code bundled with other
programs that are not linked to or dependant on MySQL for their
programs that are not linked to or dependant on MySQL
Server
for their
functionality even if you sell the distribution commercially.
functionality even if you sell the distribution commercially.
@item
@item
...
@@ -1505,7 +1512,7 @@ When using the MySQL server internally in your company.
...
@@ -1505,7 +1512,7 @@ When using the MySQL server internally in your company.
@item
@item
When include the MySQL client code in a commercial program.
When include the MySQL client code in a commercial program.
The client part of
MySQL
is licensed under the LGPL
The client part of
the MySQL software
is licensed under the LGPL
@code{GNU Lesser General Public License}. The formal terms of the
@code{GNU Lesser General Public License}. The formal terms of the
LGPL license can be found at @uref{http://www.gnu.org/licenses/}.
LGPL license can be found at @uref{http://www.gnu.org/licenses/}.
...
@@ -1529,29 +1536,31 @@ to our @code{announce} mailing list so that they can be aware of
...
@@ -1529,29 +1536,31 @@ to our @code{announce} mailing list so that they can be aware of
critical issues that may be relevant for their MySQL installations.
critical issues that may be relevant for their MySQL installations.
Note that even if an ISP does not have a commercial license for
Note that even if an ISP does not have a commercial license for
MySQL, they should at least give their customers read access to the
MySQL
Server
, they should at least give their customers read access to the
source of the MySQL installation so that the customers can verify
source of the MySQL installation so that the customers can verify
that it is patched correctly.
that it is patched correctly.
@item
@item
@cindex web server, running
@cindex web server, running
@cindex running a web server
@cindex running a web server
When you use MySQL in conjunction with a Web server, you do not need
When you use the MySQL Database Software in conjunction with a Web
a commercial license. This is true even if you run a commercial Web
server, you do not need a commercial license. This is true even if
server that uses MySQL, because you are not selling an embedded MySQL
you run a commercial Web server that uses MySQL Server, because you
version yourself. However, in this case we would like you to
are not selling an embedded MySQL version yourself. However, in this
purchase MySQL support, because MySQL is helping your enterprise.
case we would like you to purchase MySQL support, because the MySQL
@end itemize
software is helping your enterprise.
@end itemize
If your use of MySQL does not require a commercial license, we
encourage you to purchase support from MySQL AB anyway. This way
If your use of MySQL database software does not require a commercial
you contribute towards MySQL development and also gain immediate
license, we encourage you to purchase support from MySQL AB anyway.
advantages for yourself. @xref{Support}.
This way you contribute towards MySQL development and also gain
immediate advantages for yourself. @xref{Support}.
If you use MySQL in a commercial context such that you profit by
its use, we ask that you further the development of MySQL by
If you use the MySQL database software in a commercial context such
purchasing some level of support. We feel that if MySQL helps
that you profit by its use, we ask that you further the development
your business, it is reasonable to ask that you help MySQL.
of the MySQL software by purchasing some level of support. We feel
that if the MySQL database helps your business, it is reasonable to
ask that you help MySQL AB.
(Otherwise, if you ask us support questions, you are not only using
(Otherwise, if you ask us support questions, you are not only using
for free something into which we've put a lot a work, you're asking
for free something into which we've put a lot a work, you're asking
us to provide free support, too.)
us to provide free support, too.)
...
@@ -1675,7 +1684,7 @@ Please see @xref{Business Services Partnering,,Partnering}.
...
@@ -1675,7 +1684,7 @@ Please see @xref{Business Services Partnering,,Partnering}.
MySQL AB welcomes references to the MySQL database, but note that the
MySQL AB welcomes references to the MySQL database, but note that the
word @code{MySQL} is a trademark of MySQL AB. Because of this, you should
word @code{MySQL} is a trademark of MySQL AB. Because of this, you should
append the trademark symbol @code{TM} to the first or most prominent use
append the trademark symbol @code{TM} to the first or most prominent use
of the word
MySQL
in a text and where appropriate use a statement that
of the word
@code{MySQL}
in a text and where appropriate use a statement that
@code{MySQL} is a trademark of MySQL AB. Please refer to our trademark
@code{MySQL} is a trademark of MySQL AB. Please refer to our trademark
policy at @uref{http://www.mysql.com/company/trademark.html} for
policy at @uref{http://www.mysql.com/company/trademark.html} for
details.
details.
...
@@ -1694,12 +1703,12 @@ domain names is not allowed without written permission from MySQL AB.
...
@@ -1694,12 +1703,12 @@ domain names is not allowed without written permission from MySQL AB.
Dateline: 16 October 2001, Uppsala, Sweden
Dateline: 16 October 2001, Uppsala, Sweden
Long promised by MySQL AB and long awaited by our users,
Long promised by MySQL AB and long awaited by our users,
MySQL 4.0 is now available in alpha version for download from
MySQL
Server
4.0 is now available in alpha version for download from
@uref{http://www.mysql.com/} and our mirrors.
@uref{http://www.mysql.com/} and our mirrors.
Main new features of MySQL 4.0 are geared towards our existing
Main new features of MySQL
Server
4.0 are geared towards our existing
business and community users, enhancing
MySQL as the solution
business and community users, enhancing
the MySQL database software
for mission-critical, heavy load database systems.
as the solution
for mission-critical, heavy load database systems.
Other new features target the users of embedded databases.
Other new features target the users of embedded databases.
@menu
@menu
...
@@ -1715,7 +1724,7 @@ Other new features target the users of embedded databases.
...
@@ -1715,7 +1724,7 @@ Other new features target the users of embedded databases.
@node Nutshell Stepwise Rollout, Nutshell Ready for Immediate Development Use, MySQL 4.0 In A Nutshell, MySQL 4.0 In A Nutshell
@node Nutshell Stepwise Rollout, Nutshell Ready for Immediate Development Use, MySQL 4.0 In A Nutshell, MySQL 4.0 In A Nutshell
@subsection Stepwise Rollout
@subsection Stepwise Rollout
The rollout of MySQL 4.0 will come in several steps, with
The rollout of MySQL
Server
4.0 will come in several steps, with
the first version labelled 4.0.0 already containing most of the
the first version labelled 4.0.0 already containing most of the
new features. Additional features will be incorporated into
new features. Additional features will be incorporated into
MySQL 4.0.1, 4.0.2 onwards; very probably within a couple of months,
MySQL 4.0.1, 4.0.2 onwards; very probably within a couple of months,
...
@@ -1728,12 +1737,12 @@ in early 2002.
...
@@ -1728,12 +1737,12 @@ in early 2002.
@subsection Ready for Immediate Development Use
@subsection Ready for Immediate Development Use
Users are not recommended to switch their production systems
Users are not recommended to switch their production systems
to MySQL 4.0 until it is released in beta version.
to MySQL
Server
4.0 until it is released in beta version.
However, even the initial release has passed our extensive
However, even the initial release has passed our extensive
test suite without any errors on any of the platforms we test on.
test suite without any errors on any of the platforms we test on.
Due to the large number of new features, we thus recommend
Due to the large number of new features, we thus recommend
MySQL 4.0 even in alpha form for development use, with
MySQL
Server
4.0 even in alpha form for development use, with
the release schedule of MySQL 4.0 being such that it will
the release schedule of MySQL
Server
4.0 being such that it will
reach stable state before the deployment of user applications
reach stable state before the deployment of user applications
now under development.
now under development.
...
@@ -1741,17 +1750,17 @@ now under development.
...
@@ -1741,17 +1750,17 @@ now under development.
@node Nutshell Embedded MySQL, Nutshell Other features, Nutshell Ready for Immediate Development Use, MySQL 4.0 In A Nutshell
@node Nutshell Embedded MySQL, Nutshell Other features, Nutshell Ready for Immediate Development Use, MySQL 4.0 In A Nutshell
@subsection Embedded MySQL
@subsection Embedded MySQL
@code{libmysqld} makes MySQL suitable for a vastly expanded realm of
@code{libmysqld} makes MySQL
Server
suitable for a vastly expanded realm of
applications. Using the embedded MySQL server library, one can
applications. Using the embedded MySQL server library, one can
embed MySQL into various applications and electronics devices, where
embed MySQL
Server
into various applications and electronics devices, where
the end user has no knowledge of there actually being an underlying
the end user has no knowledge of there actually being an underlying
database. Embedded MySQL is ideal for use behind
database. Embedded MySQL
Server
is ideal for use behind
the scenes in internet appliances, public kiosks, turn-key
the scenes in internet appliances, public kiosks, turn-key
hardware/ software combination units, high performance internet
hardware/ software combination units, high performance internet
servers, self-contained databases distributed on CD-ROM etc.
servers, self-contained databases distributed on CD-ROM etc.
Many embedded MySQL users will benefit from the @emph{dual licensing}
Many embedded MySQL users will benefit from the @emph{dual licensing}
scheme of
MySQL
, where besides the GPL license also commercial
scheme of
the MySQL software
, where besides the GPL license also commercial
licensing is available for those not wishing to be bound by the GPL.
licensing is available for those not wishing to be bound by the GPL.
The embedded MySQL library uses the same interface as the normal
The embedded MySQL library uses the same interface as the normal
client library, so it is convenient and easy to use.
client library, so it is convenient and easy to use.
...
@@ -1762,7 +1771,8 @@ client library, so it is convenient and easy to use.
...
@@ -1762,7 +1771,8 @@ client library, so it is convenient and easy to use.
@itemize @bullet
@itemize @bullet
@item
@item
MySQL 4.0 further increases @emph{the speed of MySQL} in a number of areas,
Version 4.0 further increases @emph{the speed of MySQL Server}
in a number of areas,
such as bulk @code{INSERT}s, searching on packed indices, creation of
such as bulk @code{INSERT}s, searching on packed indices, creation of
@code{FULLTEXT} indices as well as @code{COUNT(DISTINCT)}.
@code{FULLTEXT} indices as well as @code{COUNT(DISTINCT)}.
...
@@ -1772,7 +1782,7 @@ standard MySQL server, including full support for @code{transactions}
...
@@ -1772,7 +1782,7 @@ standard MySQL server, including full support for @code{transactions}
and @code{row-level locking}.
and @code{row-level locking}.
@item
@item
MySQL 4.0 will support secure traffic between the client and the server,
MySQL
Server
4.0 will support secure traffic between the client and the server,
greatly increasing security against malicious intrusion and unauthorised
greatly increasing security against malicious intrusion and unauthorised
access. Web applications being a cornerstone of MySQL use, web developers
access. Web applications being a cornerstone of MySQL use, web developers
have been able to use SSL to secure the traffic between the
have been able to use SSL to secure the traffic between the
...
@@ -1780,7 +1790,7 @@ the end user browser and the Web application, be it written in
...
@@ -1780,7 +1790,7 @@ the end user browser and the Web application, be it written in
PHP, Perl, ASP or using any other web development tool. However,
PHP, Perl, ASP or using any other web development tool. However,
the traffic between the development tool and the mysqld server
the traffic between the development tool and the mysqld server
process has been protected only by virtue of them being processes
process has been protected only by virtue of them being processes
residing on computers within the same firewall. In MySQL 4.0,
residing on computers within the same firewall. In MySQL
Server
4.0,
the @emph{mysqld} server daemon process can itself use
the @emph{mysqld} server daemon process can itself use
@code{Secure Sockets Layer} (@code{SSL}),
@code{Secure Sockets Layer} (@code{SSL}),
thus enabling secure traffic to MySQL databases from, say, a Windows
thus enabling secure traffic to MySQL databases from, say, a Windows
...
@@ -1793,9 +1803,9 @@ Umlauts in the same order as German telephone books.
...
@@ -1793,9 +1803,9 @@ Umlauts in the same order as German telephone books.
@item
@item
Features to simplify @code{migration} from other database systems to MySQL
Features to simplify @code{migration} from other database systems to MySQL
include @code{TRUNCATE TABLE} (like in Oracle) and @code{IDENTITY} as a
Server
include @code{TRUNCATE TABLE} (like in Oracle) and @code{IDENTITY} as a
synonym for automatically incremented keys (like in Sybase). Many users will
synonym for automatically incremented keys (like in Sybase). Many users will
also be happy to learn that MySQL now supports the @code{UNION} statement,
also be happy to learn that MySQL
Server
now supports the @code{UNION} statement,
a long awaited standard SQL feature.
a long awaited standard SQL feature.
@item
@item
...
@@ -1815,12 +1825,12 @@ possible to know how many rows a query would have returned without a
...
@@ -1815,12 +1825,12 @@ possible to know how many rows a query would have returned without a
@node Nutshell Future features, Nutshell 4.1 development release, Nutshell Other features, MySQL 4.0 In A Nutshell
@node Nutshell Future features, Nutshell 4.1 development release, Nutshell Other features, MySQL 4.0 In A Nutshell
@subsection Future MySQL 4.0 Features
@subsection Future MySQL 4.0 Features
For the upcoming MySQL
4.0 releases (4.0.1, 4.0.2 and onwards), expect
For the upcoming MySQL
Server 4.0 releases (4.0.1, 4.0.2 and onwards),
the following features now still under development:
expect
the following features now still under development:
@itemize @bullet
@itemize @bullet
@item
@item
Mission-critical, heavy-load users of MySQL will appreciate
Mission-critical, heavy-load users of MySQL
Server
will appreciate
the additions to our replication system and our online hot backup.
the additions to our replication system and our online hot backup.
Later versions of 4.0 will include @code{fail-safe replication};
Later versions of 4.0 will include @code{fail-safe replication};
already in existing 4.0.0, the @code{LOAD DATA FROM MASTER} command
already in existing 4.0.0, the @code{LOAD DATA FROM MASTER} command
...
@@ -1835,11 +1845,11 @@ mysqld parameters (startup options) can soon be set without
...
@@ -1835,11 +1845,11 @@ mysqld parameters (startup options) can soon be set without
taking down the servers.
taking down the servers.
@item
@item
The new @code{FULLTEXT} search properties of MySQL
4.0 enables the us
e
The new @code{FULLTEXT} search properties of MySQL
Server 4.0 enables th
e
of @code{FULLTEXT} indexing of large text masses with both binary and
use
of @code{FULLTEXT} indexing of large text masses with both binary and
natural language searching logic. Users can customise minimal word
natural language searching logic. Users can customise minimal word
length and define their own stop word lists in any human language,
length and define their own stop word lists in any human language,
enabling a new set of applications to be built on MySQL.
enabling a new set of applications to be built on MySQL
Server
.
@item
@item
Many read-heavy applications will benefit from
Many read-heavy applications will benefit from
...
@@ -1855,17 +1865,18 @@ in the client.
...
@@ -1855,17 +1865,18 @@ in the client.
@subsection MySQL 4.1, The Following Development Release
@subsection MySQL 4.1, The Following Development Release
Internally, through a new .frm file format for table definitions,
Internally, through a new .frm file format for table definitions,
MySQL
4.0 lays the foundation for the new features of MySQL
4.1,
MySQL
Server 4.0 lays the foundation for the new features of MySQL Server
4.1,
such as @code{nested subqueries}, @code{stored procedures}, and
such as @code{nested subqueries}, @code{stored procedures}, and
@code{foreign key integrity rules}, which form the top of the
@code{foreign key integrity rules}, which form the top of the
wish list for many of our customers. Along with those, we will
wish list for many of our customers. Along with those, we will
also include simpler additions, such as
also include simpler additions, such as
multi-table @code{UPDATE} statements.
multi-table @code{UPDATE} statements.
After those additions, critics of MySQL have to be more imaginative
After those additions, critics of the MySQL Database Server have
to be more imaginative
than ever in pointing out deficiencies in the MySQL Database
than ever in pointing out deficiencies in the MySQL Database
Management System. For long already known for its stability,
Management System. For long already known for its stability,
speed, and ease of use, MySQL will then match the requirement
speed, and ease of use, MySQL
Server
will then match the requirement
checklist of very demanding buyers.
checklist of very demanding buyers.
...
@@ -1918,25 +1929,25 @@ comment on, rate, or buy them.
...
@@ -1918,25 +1929,25 @@ comment on, rate, or buy them.
While this manual (particularly the online version) is still
While this manual (particularly the online version) is still
the right place for up to date technical information, its
the right place for up to date technical information, its
primary goal is to contain everything there is to know about
primary goal is to contain everything there is to know about
MySQL. It's sometimes nice to have a bound book to read in
the MySQL database system. It's sometimes nice to have a bound
bed or while you travel.
b
ook to read in b
ed or while you travel.
By purchasing a book through the hyperlinks provided, you
By purchasing a book through the hyperlinks provided, you
will contribute to the development of
MySQL
.
will contribute to the development of
the MySQL software
.
@item Development
@item Development
This portal has links to sites that are using MySQL for various
This portal has links to sites that are using MySQL
Server
for various
purposes, with a description of each site. This information can
purposes, with a description of each site. This information can
give you an idea of who uses
MySQL and how MySQL can fulfill
give you an idea of who uses
the MySQL database software and how
their requirements.
MySQL Server can fulfill
their requirements.
Do let us know about @emph{your} site or success story too!
Do let us know about @emph{your} site or success story too!
@item Software
@item Software
Here you can find and download a multitude of applications and
Here you can find and download a multitude of applications and
wrappers that make use of
MySQL
.
wrappers that make use of
the MySQL server
.
@item Distributions
@item Distributions
From here you can find the various Linux distributions and other
From here you can find the various Linux distributions and other
software packages that contain
MySQL
.
software packages that contain
the MySQL software
.
@item Consultants
@item Consultants
Here you can find information about MySQL Consultants.
Here you can find information about MySQL Consultants.
...
@@ -2034,7 +2045,7 @@ On this list you should only post a full, repeatable bug report using
...
@@ -2034,7 +2045,7 @@ On this list you should only post a full, repeatable bug report using
the @code{mysqlbug} script (if you are running on Windows, you should
the @code{mysqlbug} script (if you are running on Windows, you should
include a description of the operating system and the MySQL version).
include a description of the operating system and the MySQL version).
Preferably, you should test the problem using the latest stable or development
Preferably, you should test the problem using the latest stable or development
version of MySQL before posting! Anyone should be able to repeat the
version of MySQL
Server
before posting! Anyone should be able to repeat the
bug by just using @code{mysql test < script} on the included test case. All
bug by just using @code{mysql test < script} on the included test case. All
bugs posted on this list will be corrected or documented in the next
bugs posted on this list will be corrected or documented in the next
MySQL release! If there are only small code changes involved, we
MySQL release! If there are only small code changes involved, we
...
@@ -2051,20 +2062,20 @@ can also discuss MySQL development and post patches.
...
@@ -2051,20 +2062,20 @@ can also discuss MySQL development and post patches.
A digest version of the @code{internals} list.
A digest version of the @code{internals} list.
@item @email{java-subscribe@@lists.mysql.com} java
@item @email{java-subscribe@@lists.mysql.com} java
Discussion about
MySQL
and Java. Mostly about the JDBC drivers.
Discussion about
the MySQL server
and Java. Mostly about the JDBC drivers.
@item @email{java-digest-subscribe@@lists.mysql.com} java-digest
@item @email{java-digest-subscribe@@lists.mysql.com} java-digest
A digest version of the @code{java} list.
A digest version of the @code{java} list.
@item @email{win32-subscribe@@lists.mysql.com} win32
@item @email{win32-subscribe@@lists.mysql.com} win32
All things concerning
MySQL on Microsoft operating systems such a
s
All things concerning
the MySQL software on Microsoft operating system
s
Win95, Win98, NT, and Win2000.
such as
Win95, Win98, NT, and Win2000.
@item @email{win32-digest-subscribe@@lists.mysql.com} win32-digest
@item @email{win32-digest-subscribe@@lists.mysql.com} win32-digest
A digest version of the @code{win32} list.
A digest version of the @code{win32} list.
@item @email{myodbc-subscribe@@lists.mysql.com} myodbc
@item @email{myodbc-subscribe@@lists.mysql.com} myodbc
All things about connecting to
MySQL
with ODBC.
All things about connecting to
the MySQL server
with ODBC.
@item @email{myodbc-digest-subscribe@@lists.mysql.com} myodbc-digest
@item @email{myodbc-digest-subscribe@@lists.mysql.com} myodbc-digest
A digest version of the @code{myodbc} list.
A digest version of the @code{myodbc} list.
...
@@ -2076,7 +2087,7 @@ All things concerning programming with the C++ API to MySQL.
...
@@ -2076,7 +2087,7 @@ All things concerning programming with the C++ API to MySQL.
A digest version of the @code{plusplus} list.
A digest version of the @code{plusplus} list.
@item @email{msql-mysql-modules-subscribe@@lists.mysql.com} msql-mysql-modules
@item @email{msql-mysql-modules-subscribe@@lists.mysql.com} msql-mysql-modules
A list about the Perl support
in MySQL. msql-mysql-modules
A list about the Perl support
for MySQL with msql-mysql-modules.
@item @email{msql-mysql-modules-digest-subscribe@@lists.mysql.com} msql-mysql-modules-digest
@item @email{msql-mysql-modules-digest-subscribe@@lists.mysql.com} msql-mysql-modules-digest
A digest version of the @code{msql-mysql-modules} list.
A digest version of the @code{msql-mysql-modules} list.
...
@@ -2186,7 +2197,7 @@ list. Note that on this list you should only post a full, repeatable bug
...
@@ -2186,7 +2197,7 @@ list. Note that on this list you should only post a full, repeatable bug
report using the @code{mysqlbug} script. If you are running on Windows,
report using the @code{mysqlbug} script. If you are running on Windows,
you should include a description of the operating system and the
you should include a description of the operating system and the
MySQL version. Preferably, you should test the problem using
MySQL version. Preferably, you should test the problem using
the latest stable or development version of MySQL before
the latest stable or development version of MySQL
Server
before
posting! Anyone should be able to repeat the bug by just using
posting! Anyone should be able to repeat the bug by just using
``@code{mysql test < script}'' on the included test case or run the
``@code{mysql test < script}'' on the included test case or run the
shell or perl script that is included in the bug report. All bugs
shell or perl script that is included in the bug report. All bugs
...
@@ -2209,7 +2220,7 @@ first time.
...
@@ -2209,7 +2220,7 @@ first time.
The most common errors are that people don't indicate the version number of
The most common errors are that people don't indicate the version number of
the MySQL distribution they are using, or don't indicate what
the MySQL distribution they are using, or don't indicate what
platform they have
MySQL
installed on (including the platform
platform they have
the MySQL server
installed on (including the platform
version number). This is highly relevant information, and in 99 cases out of
version number). This is highly relevant information, and in 99 cases out of
100 the bug report is useless without it! Very often we get questions like,
100 the bug report is useless without it! Very often we get questions like,
``Why doesn't this work for me?'' then we find that the feature
``Why doesn't this work for me?'' then we find that the feature
...
@@ -2274,7 +2285,7 @@ Sometimes the amount of memory (real and virtual) is relevant. If in doubt,
...
@@ -2274,7 +2285,7 @@ Sometimes the amount of memory (real and virtual) is relevant. If in doubt,
include these values.
include these values.
@item
@item
If you are using a source distribution of
MySQL
, the name and
If you are using a source distribution of
the MySQL software
, the name and
version number of the compiler used is needed. If you have a binary
version number of the compiler used is needed. If you have a binary
distribution, the distribution name is needed.
distribution, the distribution name is needed.
...
@@ -2343,7 +2354,7 @@ archive to @uref{ftp://support.mysql.com/pub/mysql/secret/}. Then send a
...
@@ -2343,7 +2354,7 @@ archive to @uref{ftp://support.mysql.com/pub/mysql/secret/}. Then send a
short description of the problem to @email{bugs@@lists.mysql.com}.
short description of the problem to @email{bugs@@lists.mysql.com}.
@item
@item
If you think that
MySQL
produces a strange result from a query,
If you think that
the MySQL server
produces a strange result from a query,
include not only the result, but also your opinion of what the result
include not only the result, but also your opinion of what the result
should be, and an account describing the basis for your opinion.
should be, and an account describing the basis for your opinion.
...
@@ -2402,17 +2413,17 @@ problem yourself.
...
@@ -2402,17 +2413,17 @@ problem yourself.
@item
@item
If you get a @code{parse error}, please check your syntax closely! If
If you get a @code{parse error}, please check your syntax closely! If
you can't find something wrong with it, it's extremely likely that your
you can't find something wrong with it, it's extremely likely that your
current version of MySQL doesn't support the query you are
current version of MySQL
Server
doesn't support the query you are
using. If you are using the current version and the manual at
using. If you are using the current version and the manual at
@uref{http://www.mysql.com/doc/} doesn't cover the
@uref{http://www.mysql.com/doc/} doesn't cover the
syntax you are using, MySQL doesn't support your query. In this
syntax you are using, MySQL
Server
doesn't support your query. In this
case, your only options are to implement the syntax yourself or e-mail
case, your only options are to implement the syntax yourself or e-mail
@email{mysql-licensing@@mysql.com} and ask for an offer to implement it!
@email{mysql-licensing@@mysql.com} and ask for an offer to implement it!
If the manual covers the syntax you are using, but you have an older version
If the manual covers the syntax you are using, but you have an older version
of MySQL, you should check the MySQL change history to see
of MySQL
Server
, you should check the MySQL change history to see
when the syntax was implemented. In this case, you have the option of
when the syntax was implemented. In this case, you have the option of
upgrading to a newer version of MySQL. @xref{News}.
upgrading to a newer version of MySQL
Server
. @xref{News}.
@item
@item
If you have a problem such that your data appears corrupt or you get
If you have a problem such that your data appears corrupt or you get
...
@@ -2431,11 +2442,11 @@ it's much easier for us to provide you with a fix for the problem.
...
@@ -2431,11 +2442,11 @@ it's much easier for us to provide you with a fix for the problem.
@xref{What is crashing}.
@xref{What is crashing}.
@item
@item
If possible, download and install the most recent version of MySQL
If possible, download and install the most recent version of MySQL
Server
and check whether or not it solves your problem. All versions of
and check whether or not it solves your problem. All versions of
MySQL are thoroughly tested and should work without problems. We
the MySQL software are thoroughly tested and should work without problems.
believe in making everything as backward compatible as possible, and you
We believe in making everything as backward compatible as possible,
should be able to switch MySQL versions without any hassle.
and you
should be able to switch MySQL versions without any hassle.
@xref{Which version}.
@xref{Which version}.
@end itemize
@end itemize
...
@@ -2488,34 +2499,34 @@ Many users don't read mail with a browser!
...
@@ -2488,34 +2499,34 @@ Many users don't read mail with a browser!
@cindex ANSI SQL92, extensions to
@cindex ANSI SQL92, extensions to
This section describes how MySQL relates to the ANSI SQL standards.
This section describes how MySQL relates to the ANSI SQL standards.
MySQL has many extensions to the ANSI SQL standards, and here you
MySQL
Server
has many extensions to the ANSI SQL standards, and here you
will find out what they are, and how to use them. You will also find
will find out what they are, and how to use them. You will also find
information about functionality missing from MySQL, and how to work
information about functionality missing from MySQL
Server
, and how to work
around some differences.
around some differences.
Our goal is to not, without a very good reason, restrict MySQL usability
Our goal is to not, without a very good reason, restrict MySQL
Server
usability
for any usage. Even if we don't have the resources to do development
for any usage. Even if we don't have the resources to do development
for every possible use, we are always willing to help and offer
for every possible use, we are always willing to help and offer
suggestions to people that is trying to use MySQL in new territories.
suggestions to people that is trying to use MySQL
Server
in new territories.
One of our main goals with the product is to continue to work towards
One of our main goals with the product is to continue to work towards
ANSI 99 compliancy, but without sacrificing speed or reliability.
ANSI 99 compliancy, but without sacrificing speed or reliability.
We are not afraid to add extensions to SQL or support for non-SQL
We are not afraid to add extensions to SQL or support for non-SQL
features if this greatly increase the usability of MySQL for a big
features if this greatly increase the usability of MySQL
Server
for a big
part of our users. (The new @code{HANDLER} interface in MySQL 4.0
part of our users. (The new @code{HANDLER} interface in MySQL
Server
4.0
is an example of this strategy. @xref{HANDLER}.)
is an example of this strategy. @xref{HANDLER}.)
We will continue to support transactional and not transactional
We will continue to support transactional and not transactional
databases to satisfy both heavy web/logging usage and mission critical
databases to satisfy both heavy web/logging usage and mission critical
24/7 usage.
24/7 usage.
MySQL was designed from the start to work with medium large databases
MySQL
Server
was designed from the start to work with medium large databases
(10-100 million rows / about 100 MB per table) on small computer
(10-100 million rows / about 100 MB per table) on small computer
systems. We will continue to extend MySQL to both work even better
systems. We will continue to extend MySQL
Server
to both work even better
with terabyte size databases, but we are also doing work to make it possible
with terabyte size databases, but we are also doing work to make it possible
to compile a reduced MySQL version that is more suitable for hand held
to compile a reduced MySQL version that is more suitable for hand held
devices and embedded usage. The compact design of
MySQL makes both of
devices and embedded usage. The compact design of
the MySQL server makes both
these directions possible without any conflicts in the source tree.
of
these directions possible without any conflicts in the source tree.
We are currently not targeting real time support or clustered databases
We are currently not targeting real time support or clustered databases
(even if you can already do a lot of things with our replication
(even if you can already do a lot of things with our replication
...
@@ -2554,7 +2565,7 @@ but without concessions to speed and quality of the code.
...
@@ -2554,7 +2565,7 @@ but without concessions to speed and quality of the code.
@cindex ANSI mode, running
@cindex ANSI mode, running
If you start @code{mysqld} with the @code{--ansi} option, the following
If you start @code{mysqld} with the @code{--ansi} option, the following
behavior of MySQL changes:
behavior of MySQL
Server
changes:
@itemize @bullet
@itemize @bullet
@item
@item
...
@@ -2565,7 +2576,7 @@ You can have any number of spaces between a function name and the @samp{(}.
...
@@ -2565,7 +2576,7 @@ You can have any number of spaces between a function name and the @samp{(}.
This forces all function names to be treated as reserved words.
This forces all function names to be treated as reserved words.
@item
@item
@samp{"} will be an identifier quote character (like the MySQL
@samp{"} will be an identifier quote character (like the MySQL
Server
@samp{`} quote character) and not a string quote character.
@samp{`} quote character) and not a string quote character.
@item
@item
...
@@ -2586,11 +2597,11 @@ IGNORE_SPACE,SERIALIZE,ONLY_FULL_GROUP_BY}.
...
@@ -2586,11 +2597,11 @@ IGNORE_SPACE,SERIALIZE,ONLY_FULL_GROUP_BY}.
@subsection MySQL Extensions to ANSI SQL92
@subsection MySQL Extensions to ANSI SQL92
@cindex hints
@cindex hints
MySQL includes some extensions that you probably will not find in
MySQL
Server
includes some extensions that you probably will not find in
other SQL databases. Be warned that if you use them, your code will not be
other SQL databases. Be warned that if you use them, your code will not be
portable to other SQL servers. In some cases, you can write code that
portable to other SQL servers. In some cases, you can write code that
includes MySQL extensions, but is still portable, by using comments
includes MySQL extensions, but is still portable, by using comments
of the form @code{/*! ... */}. In this case, MySQL will parse and
of the form @code{/*! ... */}. In this case, MySQL
Server
will parse and
execute the code within the comment as it would any other MySQL
execute the code within the comment as it would any other MySQL
statement, but other SQL servers will ignore the extensions. For example:
statement, but other SQL servers will ignore the extensions. For example:
...
@@ -2607,7 +2618,7 @@ CREATE /*!32302 TEMPORARY */ TABLE (a int);
...
@@ -2607,7 +2618,7 @@ CREATE /*!32302 TEMPORARY */ TABLE (a int);
@end example
@end example
The above means that if you have Version 3.23.02 or newer, then MySQL
The above means that if you have Version 3.23.02 or newer, then MySQL
will use the @code{TEMPORARY} keyword.
Server
will use the @code{TEMPORARY} keyword.
MySQL extensions are listed below:
MySQL extensions are listed below:
...
@@ -2629,7 +2640,7 @@ comparisons to be done according to the ASCII order used on the
...
@@ -2629,7 +2640,7 @@ comparisons to be done according to the ASCII order used on the
MySQL server host.
MySQL server host.
@item
@item
MySQL maps each database to a directory under the MySQL
MySQL
Server
maps each database to a directory under the MySQL
data directory, and tables within a database to filenames in the database
data directory, and tables within a database to filenames in the database
directory.
directory.
...
@@ -2643,7 +2654,7 @@ This has a few implications:
...
@@ -2643,7 +2654,7 @@ This has a few implications:
@itemize @minus
@itemize @minus
@item
@item
Database names and table names are case sensitive in MySQL on
Database names and table names are case sensitive in MySQL
Server
on
operating systems that have case-sensitive filenames (like most Unix
operating systems that have case-sensitive filenames (like most Unix
systems). @xref{Name case sensitivity}.
systems). @xref{Name case sensitivity}.
...
@@ -2661,7 +2672,7 @@ and @file{.frm} files to which the table corresponds.
...
@@ -2661,7 +2672,7 @@ and @file{.frm} files to which the table corresponds.
In SQL statements, you can access tables from different databases
In SQL statements, you can access tables from different databases
with the @code{db_name.tbl_name} syntax. Some SQL servers provide
with the @code{db_name.tbl_name} syntax. Some SQL servers provide
the same functionality but call this @code{User space}.
the same functionality but call this @code{User space}.
MySQL doesn't support tablespaces as in:
MySQL
Server
doesn't support tablespaces as in:
@code{create table ralph.my_table...IN my_tablespace}.
@code{create table ralph.my_table...IN my_tablespace}.
@item
@item
...
@@ -2751,18 +2762,18 @@ One can specify @code{ASC} and @code{DESC} with @code{GROUP BY}.
...
@@ -2751,18 +2762,18 @@ One can specify @code{ASC} and @code{DESC} with @code{GROUP BY}.
@item
@item
To make it easier for users who come from other SQL environments,
To make it easier for users who come from other SQL environments,
MySQL supports aliases for many functions. For example, all
MySQL
Server
supports aliases for many functions. For example, all
string functions support both ANSI SQL syntax and ODBC syntax.
string functions support both ANSI SQL syntax and ODBC syntax.
@item
@item
MySQL understands the @code{||} and @code{&&} operators to mean
MySQL
Server
understands the @code{||} and @code{&&} operators to mean
logical OR and AND, as in the C programming language. In MySQL,
logical OR and AND, as in the C programming language. In MySQL
Server
,
@code{||} and @code{OR} are synonyms, as are @code{&&} and @code{AND}.
@code{||} and @code{OR} are synonyms, as are @code{&&} and @code{AND}.
Because of this nice syntax, MySQL doesn't support
Because of this nice syntax, MySQL
Server
doesn't support
the ANSI SQL @code{||} operator for string concatenation; use
the ANSI SQL @code{||} operator for string concatenation; use
@code{CONCAT()} instead. Because @code{CONCAT()} takes any number
@code{CONCAT()} instead. Because @code{CONCAT()} takes any number
of arguments, it's easy to convert use of the @code{||} operator to
of arguments, it's easy to convert use of the @code{||} operator to
MySQL.
MySQL
Server
.
@item
@item
@code{CREATE DATABASE} or @code{DROP DATABASE}.
@code{CREATE DATABASE} or @code{DROP DATABASE}.
...
@@ -2795,7 +2806,7 @@ operators.
...
@@ -2795,7 +2806,7 @@ operators.
@item
@item
@code{CONCAT()} or @code{CHAR()} with one argument or more than two
@code{CONCAT()} or @code{CHAR()} with one argument or more than two
arguments. (In MySQL, these functions can take any number of
arguments. (In MySQL
Server
, these functions can take any number of
arguments.)
arguments.)
@item The @code{BIT_COUNT()}, @code{CASE}, @code{ELT()},
@item The @code{BIT_COUNT()}, @code{CASE}, @code{ELT()},
...
@@ -2832,8 +2843,8 @@ SELECT @@t1:=(@@t2:=1)+@@t3:=4,@@t1,@@t2,@@t3;
...
@@ -2832,8 +2843,8 @@ SELECT @@t1:=(@@t2:=1)+@@t3:=4,@@t1,@@t2,@@t3;
@node Differences from ANSI, Bugs, Extensions to ANSI, Compatibility
@node Differences from ANSI, Bugs, Extensions to ANSI, Compatibility
@subsection MySQL Differences Compared to ANSI SQL92
@subsection MySQL Differences Compared to ANSI SQL92
We try to make MySQL follow the ANSI SQL standard and the
We try to make MySQL
Server
follow the ANSI SQL standard and the
ODBC SQL standard, but in some cases MySQL does things
ODBC SQL standard, but in some cases MySQL
Server
does things
differently:
differently:
@itemize @bullet
@itemize @bullet
...
@@ -2867,7 +2878,7 @@ extra conditions in this case.
...
@@ -2867,7 +2878,7 @@ extra conditions in this case.
@end menu
@end menu
For a prioritised list indicating when new extensions will be added to
For a prioritised list indicating when new extensions will be added to
MySQL, you should consult the online MySQL TODO list at
MySQL
Server
, you should consult the online MySQL TODO list at
@uref{http://www.mysql.com/documentation/manual.php?section=TODO}.
@uref{http://www.mysql.com/documentation/manual.php?section=TODO}.
That is the latest version of the TODO list in this manual. @xref{TODO}.
That is the latest version of the TODO list in this manual. @xref{TODO}.
...
@@ -2877,9 +2888,9 @@ That is the latest version of the TODO list in this manual. @xref{TODO}.
...
@@ -2877,9 +2888,9 @@ That is the latest version of the TODO list in this manual. @xref{TODO}.
@cindex sub-selects
@cindex sub-selects
MySQL
currently only supports nested queries of the form @code{INSERT
MySQL
Server currently only supports nested queries of the form
... SELECT ...} and @code{REPLACE ... SELECT ...}. You can however use
@code{INSERT ... SELECT ...} and @code{REPLACE ... SELECT ...}.
the function @code{IN()} in other contexts.
You can however use
the function @code{IN()} in other contexts.
Sub-selects are scheduled for implementation in Version 4.x.
Sub-selects are scheduled for implementation in Version 4.x.
Meanwhile, you can often rewrite the query without a sub-select:
Meanwhile, you can often rewrite the query without a sub-select:
...
@@ -2913,7 +2924,7 @@ to hold the subquery. In some cases, however this option will not
...
@@ -2913,7 +2924,7 @@ to hold the subquery. In some cases, however this option will not
work. The most frequently encountered of these cases arises with
work. The most frequently encountered of these cases arises with
@code{DELETE} statements, for which standard SQL does not support joins
@code{DELETE} statements, for which standard SQL does not support joins
(except in sub-selects). For this situation there are two options
(except in sub-selects). For this situation there are two options
available until subqueries are supported by MySQL.
available until subqueries are supported by MySQL
Server
.
The first option is to use a procedural programming language (such as
The first option is to use a procedural programming language (such as
Perl or PHP) to submit a @code{SELECT} query to obtain the primary keys
Perl or PHP) to submit a @code{SELECT} query to obtain the primary keys
...
@@ -2940,9 +2951,9 @@ second instance of the interpreter:
...
@@ -2940,9 +2951,9 @@ second instance of the interpreter:
shell> mysql --skip-column-names mydb < myscript.sql | mysql mydb
shell> mysql --skip-column-names mydb < myscript.sql | mysql mydb
@end example
@end example
MySQL
4.0 supports multi-table deletes that can be used to efficiently
MySQL
Server 4.0 supports multi-table deletes that can be used to
delete rows based on information from one table or even from many tables
efficiently delete rows based on information from one table or even
at the same time.
from many tables
at the same time.
@node ANSI diff SELECT INTO TABLE, ANSI diff Transactions, ANSI diff Sub-selects, Differences from ANSI
@node ANSI diff SELECT INTO TABLE, ANSI diff Transactions, ANSI diff Sub-selects, Differences from ANSI
...
@@ -2950,8 +2961,8 @@ at the same time.
...
@@ -2950,8 +2961,8 @@ at the same time.
@findex SELECT INTO TABLE
@findex SELECT INTO TABLE
MySQL doesn't yet support the Oracle SQL extension:
MySQL
Server
doesn't yet support the Oracle SQL extension:
@code{SELECT ... INTO TABLE ...}. MySQL supports instead the
@code{SELECT ... INTO TABLE ...}. MySQL
Server
supports instead the
ANSI SQL syntax @code{INSERT INTO ... SELECT ...}, which is basically
ANSI SQL syntax @code{INSERT INTO ... SELECT ...}, which is basically
the same thing. @xref{INSERT SELECT}.
the same thing. @xref{INSERT SELECT}.
...
@@ -2977,20 +2988,20 @@ TABLE ... SELECT}.
...
@@ -2977,20 +2988,20 @@ TABLE ... SELECT}.
@cindex @code{BDB} tables
@cindex @code{BDB} tables
@cindex @code{ACID}
@cindex @code{ACID}
MySQL supports transactions with the @code{InnoDB} and @code{BDB}
MySQL
Server
supports transactions with the @code{InnoDB} and @code{BDB}
@code{Transactional table handlers}. @xref{Table types}.
@code{Transactional table handlers}. @xref{Table types}.
@code{InnoDB} provides @code{ACID} compliancy.
@code{InnoDB} provides @code{ACID} compliancy.
However, the non-transactional table types in MySQL such as
However, the non-transactional table types in MySQL
Server
such as
@code{MyISAM} follow another paradigm for data integrity called
@code{MyISAM} follow another paradigm for data integrity called
``@code{Atomic Operations}.'' Atomic operations often offer equal or
``@code{Atomic Operations}.'' Atomic operations often offer equal or
even better integrity with much better performance.
even better integrity with much better performance.
With MySQL supporting both paradigms, the user is able to decide if
With MySQL
Server
supporting both paradigms, the user is able to decide if
they need the speed of atomic operations or if they need to use
they need the speed of atomic operations or if they need to use
transactional features in their applications. This choice can be made
transactional features in their applications. This choice can be made
on a per-table basis.
on a per-table basis.
How does one use the features of MySQL to maintain rigorous integrity
How does one use the features of MySQL
Server
to maintain rigorous integrity
and how do these features compare with the transactional paradigm?
and how do these features compare with the transactional paradigm?
@enumerate
@enumerate
...
@@ -3003,7 +3014,7 @@ corrupting activities are not committed to the database; the server is
...
@@ -3003,7 +3014,7 @@ corrupting activities are not committed to the database; the server is
given the opportunity to do an automatic rollback and your database is
given the opportunity to do an automatic rollback and your database is
saved.
saved.
MySQL, in almost all cases, allows you to resolve potential problems
MySQL
Server
, in almost all cases, allows you to resolve potential problems
by including simple checks before updates and by running simple scripts
by including simple checks before updates and by running simple scripts
that check the databases for inconsistencies and automatically repair
that check the databases for inconsistencies and automatically repair
or warn if such an inconsistency occurs. Note that just by using the
or warn if such an inconsistency occurs. Note that just by using the
...
@@ -3025,7 +3036,7 @@ time-lap is where they could lose data. No system is 100% secure, only
...
@@ -3025,7 +3036,7 @@ time-lap is where they could lose data. No system is 100% secure, only
transactional databases, is reported to sometimes lose data in such
transactional databases, is reported to sometimes lose data in such
situations.
situations.
To be safe with MySQL, whether using transactional tables or not, you
To be safe with MySQL
Server
, whether using transactional tables or not, you
only need to have backups and have the update logging turned on. With
only need to have backups and have the update logging turned on. With
this you can recover from any situation that you could with any
this you can recover from any situation that you could with any
other transactional database. It is, of course, always good to have
other transactional database. It is, of course, always good to have
...
@@ -3040,7 +3051,7 @@ familiar with transactions, do consider the speed benefit that
...
@@ -3040,7 +3051,7 @@ familiar with transactions, do consider the speed benefit that
non-transactional tables can offer, on the order of three to five times
non-transactional tables can offer, on the order of three to five times
the speed of the fastest and most optimally tuned transactional tables.
the speed of the fastest and most optimally tuned transactional tables.
In situations where integrity is of highest importance, MySQL offers
In situations where integrity is of highest importance, MySQL
Server
offers
transaction-level or better reliability and integrity even for
transaction-level or better reliability and integrity even for
non-transactional tables.
non-transactional tables.
If you lock tables with @code{LOCK TABLES}, all updates will stall
If you lock tables with @code{LOCK TABLES}, all updates will stall
...
@@ -3056,7 +3067,7 @@ for the insert to complete. @xref{INSERT DELAYED}.
...
@@ -3056,7 +3067,7 @@ for the insert to complete. @xref{INSERT DELAYED}.
means that you can be sure that while each specific update is running,
means that you can be sure that while each specific update is running,
no other user can interfere with it, and there will never be an
no other user can interfere with it, and there will never be an
automatic rollback (which can happen with transactional tables if you
automatic rollback (which can happen with transactional tables if you
are not very careful). MySQL also guarantees that there will not be
are not very careful). MySQL
Server
also guarantees that there will not be
any dirty reads.
any dirty reads.
Following are some techniques for working with non-transactional tables:
Following are some techniques for working with non-transactional tables:
...
@@ -3152,7 +3163,7 @@ UPDATE tbl_name SET row_flag=1 WHERE id=ID;
...
@@ -3152,7 +3163,7 @@ UPDATE tbl_name SET row_flag=1 WHERE id=ID;
MySQL returns 1 for the number of affected rows if the row was
MySQL returns 1 for the number of affected rows if the row was
found and @code{row_flag} wasn't already 1 in the original row.
found and @code{row_flag} wasn't already 1 in the original row.
You can think of it as MySQL changed the above query to:
You can think of it as MySQL
Server
changed the above query to:
@example
@example
UPDATE tbl_name SET row_flag=1 WHERE id=ID and row_flag <> 1;
UPDATE tbl_name SET row_flag=1 WHERE id=ID and row_flag <> 1;
...
@@ -3181,7 +3192,7 @@ deletes the corresponding customer from a customer table when all his
...
@@ -3181,7 +3192,7 @@ deletes the corresponding customer from a customer table when all his
transactions are deleted.
transactions are deleted.
The planned update language will be able to handle stored procedures.
The planned update language will be able to handle stored procedures.
Our aim is to have stored procedures implemented in MySQL 4.1.
Our aim is to have stored procedures implemented in MySQL
Server
4.1.
We are also looking at triggers.
We are also looking at triggers.
...
@@ -3202,8 +3213,8 @@ SELECT * from table1,table2 where table1.id = table2.id;
...
@@ -3202,8 +3213,8 @@ SELECT * from table1,table2 where table1.id = table2.id;
@xref{JOIN, , @code{JOIN}}. @xref{example-Foreign keys}.
@xref{JOIN, , @code{JOIN}}. @xref{example-Foreign keys}.
In MySQL 3.23.44 and up, @code{InnoDB} tables supports checking of
In MySQL
Server
3.23.44 and up, @code{InnoDB} tables supports checking of
foreign key constraints. @xref{InnoDB}. For other table types, MySQL
foreign key constraints. @xref{InnoDB}. For other table types, MySQL
Server
does parse the @code{FOREIGN KEY} syntax in @code{CREATE TABLE}
does parse the @code{FOREIGN KEY} syntax in @code{CREATE TABLE}
commands, but without further action being taken.
commands, but without further action being taken.
...
@@ -3214,13 +3225,13 @@ override. @code{FOREIGN KEY} is sometimes used as a constraint check,
...
@@ -3214,13 +3225,13 @@ override. @code{FOREIGN KEY} is sometimes used as a constraint check,
but this check is unnecessary in practice if rows are inserted into the
but this check is unnecessary in practice if rows are inserted into the
tables in the right order.
tables in the right order.
In MySQL, you can work around the problem of @code{ON DELETE ...} not
In MySQL
Server
, you can work around the problem of @code{ON DELETE ...} not
being implemented by adding the appropriate @code{DELETE} statement to
being implemented by adding the appropriate @code{DELETE} statement to
an application when you delete records from a table that has a foreign
an application when you delete records from a table that has a foreign
key. In practice this is as quick (in some cases quicker) and much more
key. In practice this is as quick (in some cases quicker) and much more
portable than using foreign keys.
portable than using foreign keys.
In MySQL 4.0 you can use multi-table delete to delete rows from many
In MySQL
Server
4.0 you can use multi-table delete to delete rows from many
tables with one command. @xref{DELETE}.
tables with one command. @xref{DELETE}.
In the near future we will extend the @code{FOREIGN KEY} implementation
In the near future we will extend the @code{FOREIGN KEY} implementation
...
@@ -3276,20 +3287,20 @@ to backup or restore individual tables.
...
@@ -3276,20 +3287,20 @@ to backup or restore individual tables.
@cindex views
@cindex views
It is planned to implement views in MySQL around Version 4.1.
It is planned to implement views in MySQL
Server
around Version 4.1.
Views are mostly useful for letting users access a set of relations as one
Views are mostly useful for letting users access a set of relations as one
table (in read-only mode). Many SQL databases don't allow one to update
table (in read-only mode). Many SQL databases don't allow one to update
any rows in a view, but you have to do the updates in the separate tables.
any rows in a view, but you have to do the updates in the separate tables.
As MySQL is mostly used in applications and on web system where
As MySQL
Server
is mostly used in applications and on web system where
the application writer has full control on the database usage, most of
the application writer has full control on the database usage, most of
our users haven't regarded views to be very important.
our users haven't regarded views to be very important.
(At least no one has been interested enough in this to be prepared to
(At least no one has been interested enough in this to be prepared to
finance the implementation of views).
finance the implementation of views).
One doesn't need views in MySQL to restrict access to columns
One doesn't need views in MySQL
Server
to restrict access to columns
as MySQL has a very sophisticated privilege system.
as MySQL
Server
has a very sophisticated privilege system.
@xref{Privilege system}.
@xref{Privilege system}.
...
@@ -3300,11 +3311,11 @@ as MySQL has a very sophisticated privilege system.
...
@@ -3300,11 +3311,11 @@ as MySQL has a very sophisticated privilege system.
@cindex starting, comments
@cindex starting, comments
Some other SQL databases use @samp{--} to start comments.
Some other SQL databases use @samp{--} to start comments.
MySQL has @samp{#} as the start comment character. You can also use
MySQL
Server
has @samp{#} as the start comment character. You can also use
the C comment style @code{/* this is a comment */} with MySQL.
the C comment style @code{/* this is a comment */} with MySQL
Server
.
@xref{Comments}.
@xref{Comments}.
MySQL Version 3.23.3 and above supports the @samp{--} comment style,
MySQL
Server
Version 3.23.3 and above supports the @samp{--} comment style,
provided the comment is followed by a space. This is because this
provided the comment is followed by a space. This is because this
comment style has caused many problems with automatically generated
comment style has caused many problems with automatically generated
SQL queries that have used something like the following code, where
SQL queries that have used something like the following code, where
...
@@ -3319,7 +3330,7 @@ Think about what happens if the value of @code{payment} is negative?
...
@@ -3319,7 +3330,7 @@ Think about what happens if the value of @code{payment} is negative?
Because @code{1--1} is legal in SQL, the consequences of allowing
Because @code{1--1} is legal in SQL, the consequences of allowing
comments to start with @samp{--} are terrible.
comments to start with @samp{--} are terrible.
Using our implementation of this method of commenting in MySQL
Using our implementation of this method of commenting in MySQL
Server
Version 3.23.3 and up, @code{1-- This is a comment} is actually safe.
Version 3.23.3 and up, @code{1-- This is a comment} is actually safe.
Another safe feature is that the @code{mysql} command-line client
Another safe feature is that the @code{mysql} command-line client
...
@@ -3438,13 +3449,13 @@ precision, @code{IF}, and @code{ELT()} with @code{BIGINT} or @code{DOUBLE}
...
@@ -3438,13 +3449,13 @@ precision, @code{IF}, and @code{ELT()} with @code{BIGINT} or @code{DOUBLE}
precision and the rest with @code{DOUBLE} precision. One should try to
precision and the rest with @code{DOUBLE} precision. One should try to
avoid using bigger unsigned long long values than 63 bits
avoid using bigger unsigned long long values than 63 bits
(9223372036854775807) for anything else than bit fields!
(9223372036854775807) for anything else than bit fields!
MySQL 4.0 has better @code{BIGINT} handling than 3.23.
MySQL
Server
4.0 has better @code{BIGINT} handling than 3.23.
@item
@item
All string columns, except @code{BLOB} and @code{TEXT} columns, automatically
All string columns, except @code{BLOB} and @code{TEXT} columns, automatically
have all trailing spaces removed when retrieved. For @code{CHAR} types this
have all trailing spaces removed when retrieved. For @code{CHAR} types this
is okay, and may be regarded as a feature according to ANSI SQL92. The bug is
is okay, and may be regarded as a feature according to ANSI SQL92. The bug is
that in MySQL, @code{VARCHAR} columns are treated the same way.
that in MySQL
Server
, @code{VARCHAR} columns are treated the same way.
@item
@item
You can only have up to 255 @code{ENUM} and @code{SET} columns in one table.
You can only have up to 255 @code{ENUM} and @code{SET} columns in one table.
...
@@ -3507,7 +3518,7 @@ SELECT DISTINCT band_downloads.mp3id
...
@@ -3507,7 +3518,7 @@ SELECT DISTINCT band_downloads.mp3id
ORDER BY band_downloads.id DESC;
ORDER BY band_downloads.id DESC;
@end example
@end example
In the second case you may in MySQL 3.23.x get two identical rows
In the second case you may in MySQL
Server
3.23.x get two identical rows
in the result set (because the hidden 'id' column may differ).
in the result set (because the hidden 'id' column may differ).
Note that the this only happens for queries where you don't have the
Note that the this only happens for queries where you don't have the
...
@@ -3515,38 +3526,38 @@ ORDER BY columns in the result, something that is you are not allowed
...
@@ -3515,38 +3526,38 @@ ORDER BY columns in the result, something that is you are not allowed
to do in ANSI SQL.
to do in ANSI SQL.
@item
@item
Because MySQL allows you to work with table types that don't
Because MySQL
Server
allows you to work with table types that don't
support transactions, and thus can't @code{rollback} data, some things
support transactions, and thus can't @code{rollback} data, some things
behave a little differently in MySQL than in other SQL servers.
behave a little differently in MySQL
Server
than in other SQL servers.
This is just to ensure that MySQL never need to do a rollback
This is just to ensure that MySQL
Server
never need to do a rollback
for a SQL command. This may be a little awkward at times as column
for a SQL command. This may be a little awkward at times as column
values must be checked in the application, but this will actually give
values must be checked in the application, but this will actually give
you a nice speed increase as it allows MySQL to do some
you a nice speed increase as it allows MySQL
Server
to do some
optimisations that otherwise would be very hard to do.
optimisations that otherwise would be very hard to do.
If you set a column to an incorrect value, MySQL will, instead of
If you set a column to an incorrect value, MySQL
Server
will, instead of
doing a rollback, store the @code{best possible value} in the column:
doing a rollback, store the @code{best possible value} in the column:
@itemize @minus
@itemize @minus
@item
@item
If you try to store a value outside the range in a numerical column,
If you try to store a value outside the range in a numerical column,
MySQL will instead store the smallest or biggest possible value in
MySQL
Server
will instead store the smallest or biggest possible value in
the column.
the column.
@item
@item
If you try to store a string that doesn't start with a number into a
If you try to store a string that doesn't start with a number into a
numerical column, MySQL will store 0 into it.
numerical column, MySQL
Server
will store 0 into it.
@item
@item
If you try to store @code{NULL} into a column that doesn't take
If you try to store @code{NULL} into a column that doesn't take
@code{NULL} values, MySQL will store 0 or @code{''} (empty
@code{NULL} values, MySQL
Server
will store 0 or @code{''} (empty
string) in it instead. (This behavior can, however, be changed with the
string) in it instead. (This behavior can, however, be changed with the
-DDONT_USE_DEFAULT_FIELDS compile option).
-DDONT_USE_DEFAULT_FIELDS compile option).
@item
@item
MySQL allows you to store some wrong date values into
MySQL allows you to store some wrong date values into
@code{DATE} and @code{DATETIME} columns. (Like 2000-02-31 or 2000-02-00).
@code{DATE} and @code{DATETIME} columns. (Like 2000-02-31 or 2000-02-00).
If the date is totally wrong, MySQL will store the special
If the date is totally wrong, MySQL
Server
will store the special
0000-00-00 date value in the column.
0000-00-00 date value in the column.
@item
@item
...
@@ -3568,7 +3579,7 @@ Creation of a table of type @code{MERGE} doesn't check if the underlying
...
@@ -3568,7 +3579,7 @@ Creation of a table of type @code{MERGE} doesn't check if the underlying
tables are of compatible types.
tables are of compatible types.
@item
@item
MySQL can't yet handle @code{NaN}, @code{-Inf} and @code{Inf}
MySQL
Server
can't yet handle @code{NaN}, @code{-Inf} and @code{Inf}
values in double. Using these will cause problems when trying to export
values in double. Using these will cause problems when trying to export
and import data. We should as an intermediate solution change @code{NaN} to
and import data. We should as an intermediate solution change @code{NaN} to
@code{NULL} (if possible) and @code{-Inf} and @code{Inf} to the
@code{NULL} (if possible) and @code{-Inf} and @code{Inf} to the
...
@@ -3608,7 +3619,7 @@ Delayed insert handler has pending inserts to a table.
...
@@ -3608,7 +3619,7 @@ Delayed insert handler has pending inserts to a table.
@end itemize
@end itemize
@item
@item
Before MySQL Version 3.23.2 an @code{UPDATE} that updated a key with
Before MySQL
Server
Version 3.23.2 an @code{UPDATE} that updated a key with
a @code{WHERE} on the same key may have failed because the key was used to
a @code{WHERE} on the same key may have failed because the key was used to
search for records and the same row may have been found multiple times:
search for records and the same row may have been found multiple times:
...
@@ -3622,14 +3633,14 @@ A workaround is to use:
...
@@ -3622,14 +3633,14 @@ A workaround is to use:
mysql> UPDATE tbl_name SET KEY=KEY+1 WHERE KEY+0 > 100;
mysql> UPDATE tbl_name SET KEY=KEY+1 WHERE KEY+0 > 100;
@end example
@end example
This will work because MySQL will not use index on expressions in
This will work because MySQL
Server
will not use index on expressions in
the @code{WHERE} clause.
the @code{WHERE} clause.
@item
@item
Before MySQL
Version 3.23, all numeric types where treated as fixed-point
Before MySQL
Server Version 3.23, all numeric types where treated as
fi
elds. That means you had to specify how many decimals a floating-point
fi
xed-point fields. That means you had to specify how many decimals
field shall have. All results were returned with the correct number of
a floating-point field shall have. All results were returned with the
decimals.
correct number of
decimals.
@end itemize
@end itemize
For platform-specific bugs, see the sections about compiling and porting.
For platform-specific bugs, see the sections about compiling and porting.
...
@@ -3647,7 +3658,7 @@ For platform-specific bugs, see the sections about compiling and porting.
...
@@ -3647,7 +3658,7 @@ For platform-specific bugs, see the sections about compiling and porting.
* TODO unplanned:: Things we don't Have any Plans to do
* TODO unplanned:: Things we don't Have any Plans to do
@end menu
@end menu
This appendix lists the features that we plan to implement in MySQL.
This appendix lists the features that we plan to implement in MySQL
Server
.
Everything in this list is approximately in the order it will be done. If you
Everything in this list is approximately in the order it will be done. If you
want to affect the priority order, please register a license or support us and
want to affect the priority order, please register a license or support us and
...
@@ -3661,16 +3672,16 @@ this without sacrifying the speed or compromise the code.
...
@@ -3661,16 +3672,16 @@ this without sacrifying the speed or compromise the code.
@node TODO MySQL 4.0, TODO future, TODO, TODO
@node TODO MySQL 4.0, TODO future, TODO, TODO
@subsection Things That Should be in 4.0
@subsection Things That Should be in 4.0
We have now shifted development to MySQL
Version
4.0. Most of the basic
We have now shifted development to MySQL
Server
4.0. Most of the basic
things we want to have in 4.0 are already done. The target is to quickly
things we want to have in 4.0 are already done. The target is to quickly
implement the rest of the following features and then shift development
implement the rest of the following features and then shift development
to MySQL 4.1. @xref{MySQL 4.0 In A Nutshell}.
to MySQL
Server
4.1. @xref{MySQL 4.0 In A Nutshell}.
The news section for 4.0 includes a list of the features we have already
The news section for 4.0 includes a list of the features we have already
implemented in the 4.0 tree. @xref{News-4.0.x}.
implemented in the 4.0 tree. @xref{News-4.0.x}.
This section lists features not yet implemented in the current
This section lists features not yet implemented in the current
version of MySQL 4.0, which will however be implemented in
version of MySQL
Server
4.0, which will however be implemented in
later versions of MySQL 4.0. This being very volatile information,
later versions of MySQL 4.0. This being very volatile information,
please consider this list valid only if you are reading it from
please consider this list valid only if you are reading it from
the MySQL web site (@uref{http://www.mysql.com/}).
the MySQL web site (@uref{http://www.mysql.com/}).
...
@@ -3737,7 +3748,7 @@ corrupt the table.
...
@@ -3737,7 +3748,7 @@ corrupt the table.
@itemize @bullet
@itemize @bullet
@item
@item
Subqueries.
Subqueries.
@code{
select id from t where grp in (select grp from g where
u > 100)}
@code{
SELECT id FROM t WHERE grp IN (SELECT grp FROM g WHERE
u > 100)}
@item
@item
Atomic multi-table updates, eg @code{update items,month set
Atomic multi-table updates, eg @code{update items,month set
items.price=month.price where items.id=month.id;};
items.price=month.price where items.id=month.id;};
...
@@ -3798,7 +3809,7 @@ options like database in use, time and date...
...
@@ -3798,7 +3809,7 @@ options like database in use, time and date...
@item
@item
Link the @code{myisampack} code into the server.
Link the @code{myisampack} code into the server.
@item
@item
Port of
MySQL
to BeOS.
Port of
the MySQL code
to BeOS.
@item
@item
Port of the MySQL clients to LynxOS.
Port of the MySQL clients to LynxOS.
@item
@item
...
@@ -4119,10 +4130,11 @@ Nothing; We aim towards full ANSI 92 / ANSI 99 compliancy.
...
@@ -4119,10 +4130,11 @@ Nothing; We aim towards full ANSI 92 / ANSI 99 compliancy.
@cindex comparisons, MySQL vs. others
@cindex comparisons, MySQL vs. others
Our users have successfully run their own benchmarks against a number
Our users have successfully run their own benchmarks against a number
of @code{Open Source} and traditional database servers. We are aware of
of @code{Open Source} and traditional database servers.
tests against @code{Oracle}, @code{DB/2}, @code{Microsoft SQL Server}
We are aware of tests against @code{Oracle} server, @code{DB/2} server,
and other commercial products. Due to legal reasons we are restricted
@code{Microsoft SQL Server} and other commercial products.
from publishing some of those benchmarks in our reference manual.
Due to legal reasons we are restricted from publishing some of those
benchmarks in our reference manual.
This section includes a comparison with @code{mSQL} for historical
This section includes a comparison with @code{mSQL} for historical
reasons and with @code{PostgreSQL} as it is also an Open Source
reasons and with @code{PostgreSQL} as it is also an Open Source
...
@@ -4171,9 +4183,9 @@ easy.)
...
@@ -4171,9 +4183,9 @@ easy.)
Because these operations are so simple, it is hard to be better at
Because these operations are so simple, it is hard to be better at
them when you have a higher startup overhead. After the connection
them when you have a higher startup overhead. After the connection
is established, MySQL should perform much better.
is established, MySQL
Server
should perform much better.
On the other hand, MySQL is much faster than @code{mSQL} (and
On the other hand, MySQL
Server
is much faster than @code{mSQL} (and
most other SQL implementations) on the following:
most other SQL implementations) on the following:
@itemize @bullet
@itemize @bullet
...
@@ -4181,11 +4193,11 @@ most other SQL implementations) on the following:
...
@@ -4181,11 +4193,11 @@ most other SQL implementations) on the following:
Complex @code{SELECT} operations.
Complex @code{SELECT} operations.
@item
@item
Retrieving large results (MySQL has a better, faster, and safer
Retrieving large results (MySQL
Server
has a better, faster, and safer
protocol).
protocol).
@item
@item
Tables with variable-length strings, because MySQL has more efficient
Tables with variable-length strings, because MySQL
Server
has more efficient
handling and can have indexes on @code{VARCHAR} columns.
handling and can have indexes on @code{VARCHAR} columns.
@item
@item
...
@@ -4201,7 +4213,7 @@ Handling tables with large record lengths.
...
@@ -4201,7 +4213,7 @@ Handling tables with large record lengths.
@code{SELECT} on large tables.
@code{SELECT} on large tables.
@item
@item
Handling many connections at the same time. MySQL is fully
Handling many connections at the same time. MySQL
Server
is fully
multi-threaded. Each connection has its own thread, which means that
multi-threaded. Each connection has its own thread, which means that
no thread has to wait for another (unless a thread is modifying
no thread has to wait for another (unless a thread is modifying
a table another thread wants to access). In @code{mSQL}, once one
a table another thread wants to access). In @code{mSQL}, once one
...
@@ -4214,7 +4226,7 @@ next can be served, while all the others wait again, etc.
...
@@ -4214,7 +4226,7 @@ next can be served, while all the others wait again, etc.
Joins.
Joins.
@code{mSQL} can become pathologically slow if you change the order of
@code{mSQL} can become pathologically slow if you change the order of
tables in a @code{SELECT}. In the benchmark suite, a time more than
tables in a @code{SELECT}. In the benchmark suite, a time more than
15000 times slower than MySQL was seen. This is due to @code{mSQL}'s
15000 times slower than MySQL
Server
was seen. This is due to @code{mSQL}'s
lack of a join optimiser to order tables in the optimal order.
lack of a join optimiser to order tables in the optimal order.
However, if you put the tables in exactly the right order in
However, if you put the tables in exactly the right order in
@code{mSQL}2 and the @code{WHERE} is simple and uses index columns,
@code{mSQL}2 and the @code{WHERE} is simple and uses index columns,
...
@@ -4236,7 +4248,7 @@ Using @code{TEXT} or @code{BLOB} columns.
...
@@ -4236,7 +4248,7 @@ Using @code{TEXT} or @code{BLOB} columns.
@itemize @bullet
@itemize @bullet
@item @code{GROUP BY} and @code{HAVING}.
@item @code{GROUP BY} and @code{HAVING}.
@code{mSQL} does not support @code{GROUP BY} at all.
@code{mSQL} does not support @code{GROUP BY} at all.
MySQL supports a full @code{GROUP BY} with both @code{HAVING} and
MySQL
Server
supports a full @code{GROUP BY} with both @code{HAVING} and
the following functions: @code{COUNT()}, @code{AVG()}, @code{MIN()},
the following functions: @code{COUNT()}, @code{AVG()}, @code{MIN()},
@code{MAX()}, @code{SUM()}, and @code{STD()}. @code{COUNT(*)} is
@code{MAX()}, @code{SUM()}, and @code{STD()}. @code{COUNT(*)} is
optimised to return very quickly if the @code{SELECT} retrieves from
optimised to return very quickly if the @code{SELECT} retrieves from
...
@@ -4245,7 +4257,7 @@ one table, no other columns are retrieved, and there is no
...
@@ -4245,7 +4257,7 @@ one table, no other columns are retrieved, and there is no
arguments.
arguments.
@item @code{INSERT} and @code{UPDATE} with calculations.
@item @code{INSERT} and @code{UPDATE} with calculations.
MySQL can do calculations in an @code{INSERT} or @code{UPDATE}.
MySQL
Server
can do calculations in an @code{INSERT} or @code{UPDATE}.
For example:
For example:
@example
@example
...
@@ -4253,21 +4265,21 @@ mysql> UPDATE SET x=x*10+y WHERE x<20;
...
@@ -4253,21 +4265,21 @@ mysql> UPDATE SET x=x*10+y WHERE x<20;
@end example
@end example
@item Aliasing.
@item Aliasing.
MySQL has column aliasing.
MySQL
Server
has column aliasing.
@item Qualifying column names.
@item Qualifying column names.
In MySQL, if a column name is unique among the tables used in a
In MySQ
Server
L, if a column name is unique among the tables used in a
query, you do not have to use the full qualifier.
query, you do not have to use the full qualifier.
@item @code{SELECT} with functions.
@item @code{SELECT} with functions.
MySQL has many functions (too many to list here; see @ref{Functions}).
MySQL
Server
has many functions (too many to list here; see @ref{Functions}).
@end itemize
@end itemize
@item Disk Space Efficiency
@item Disk Space Efficiency
That is, how small can you make your tables?
That is, how small can you make your tables?
MySQL has very precise types, so you can create tables that take
MySQ
Server
L has very precise types, so you can create tables that take
very little space. An example of a useful MySQL datatype is the
very little space. An example of a useful MySQL datatype is the
@code{MEDIUMINT} that is 3 bytes long. If you have 100,000,000
@code{MEDIUMINT} that is 3 bytes long. If you have 100,000,000
records, saving even one byte per record is very important.
records, saving even one byte per record is very important.
...
@@ -4276,24 +4288,24 @@ records, saving even one byte per record is very important.
...
@@ -4276,24 +4288,24 @@ records, saving even one byte per record is very important.
more difficult to get small tables.
more difficult to get small tables.
@item Stability
@item Stability
This is harder to judge objectively. For a discussion of MySQL
This is harder to judge objectively. For a discussion of MySQL
Server
stability, see @ref{Stability}.
stability, see @ref{Stability}.
We have no experience with @code{mSQL} stability, so we cannot say
We have no experience with @code{mSQL} stability, so we cannot say
anything about that.
anything about that.
@item Price
@item Price
Another important issue is the license. MySQL has a
Another important issue is the license. MySQL
Server
has a
more flexible license than @code{mSQL}, and is also less expensive
more flexible license than @code{mSQL}, and is also less expensive
than @code{mSQL}. Whichever product you choose to use, remember to
than @code{mSQL}. Whichever product you choose to use, remember to
at least consider paying for a license or e-mail support.
at least consider paying for a license or e-mail support.
@item Perl Interfaces
@item Perl Interfaces
MySQL has basically the same interfaces to Perl as @code{mSQL} with
MySQL
Server
has basically the same interfaces to Perl as @code{mSQL} with
some added features.
some added features.
@item JDBC (Java)
@item JDBC (Java)
MySQL currently has a lot of different JDBC drivers:
MySQL
Server
currently has a lot of different JDBC drivers:
@itemize @bullet
@itemize @bullet
@item
@item
...
@@ -4325,7 +4337,7 @@ We know that @code{mSQL} has a JDBC driver, but we have too little
...
@@ -4325,7 +4337,7 @@ We know that @code{mSQL} has a JDBC driver, but we have too little
experience with it to compare.
experience with it to compare.
@item Rate of Development
@item Rate of Development
MySQL has a small core team of developers, but we are quite
MySQL
Server
has a small core team of developers, but we are quite
used to coding C and C++ very rapidly. Because threads, functions,
used to coding C and C++ very rapidly. Because threads, functions,
@code{GROUP BY}, and so on are still not implemented in @code{mSQL}, it
@code{GROUP BY}, and so on are still not implemented in @code{mSQL}, it
has a lot of catching up to do. To get some perspective on this, you
has a lot of catching up to do. To get some perspective on this, you
...
@@ -4335,17 +4347,17 @@ compare it with the News section of the MySQL Reference Manual
...
@@ -4335,17 +4347,17 @@ compare it with the News section of the MySQL Reference Manual
most rapidly.
most rapidly.
@item Utility Programs
@item Utility Programs
Both @code{mSQL} and MySQL have many interesting third-party
Both @code{mSQL} and MySQL
Server
have many interesting third-party
tools. Because it is very easy to port upward (from @code{mSQL} to
tools. Because it is very easy to port upward (from @code{mSQL} to
MySQL), almost all the interesting applications that are available for
MySQL
Server
), almost all the interesting applications that are available for
@code{mSQL} are also available for MySQL.
@code{mSQL} are also available for MySQ
Server
L.
MySQL comes with a simple @code{msql2mysql} program that fixes
MySQL
Server
comes with a simple @code{msql2mysql} program that fixes
differences in spelling between @code{mSQL} and MySQL for the
differences in spelling between @code{mSQL} and MySQL
Server
for the
most-used C API functions.
most-used C API functions.
For example, it changes instances of @code{msqlConnect()} to
For example, it changes instances of @code{msqlConnect()} to
@code{mysql_connect()}. Converting a client program from @code{mSQL} to
@code{mysql_connect()}. Converting a client program from @code{mSQL} to
MySQL usually requires only minor effort.
MySQL
Server
usually requires only minor effort.
@end table
@end table
@menu
@menu
...
@@ -4371,7 +4383,7 @@ The conversion procedure is:
...
@@ -4371,7 +4383,7 @@ The conversion procedure is:
@enumerate
@enumerate
@item
@item
Run the shell script @code{msql2mysql} on the source. This requires
Run the shell script @code{msql2mysql} on the source. This requires
the @code{replace} program, which is distributed with MySQL.
the @code{replace} program, which is distributed with MySQL
Server
.
@item
@item
Compile.
Compile.
...
@@ -4384,7 +4396,7 @@ Differences between the @code{mSQL} C API and the MySQL C API are:
...
@@ -4384,7 +4396,7 @@ Differences between the @code{mSQL} C API and the MySQL C API are:
@itemize @bullet
@itemize @bullet
@item
@item
MySQL uses a @code{MYSQL} structure as a connection type (@code{mSQL}
MySQL
Server
uses a @code{MYSQL} structure as a connection type (@code{mSQL}
uses an @code{int}).
uses an @code{int}).
@item
@item
...
@@ -4400,11 +4412,11 @@ Just add the parameter to your old @code{msql_error()} code if you are
...
@@ -4400,11 +4412,11 @@ Just add the parameter to your old @code{msql_error()} code if you are
porting old code.
porting old code.
@item
@item
MySQL returns an error number and a text error message for all
MySQL
Server
returns an error number and a text error message for all
errors. @code{mSQL} returns only a text error message.
errors. @code{mSQL} returns only a text error message.
@item
@item
Some incompatibilities exist as a result of MySQL supporting
Some incompatibilities exist as a result of MySQL
Server
supporting
multiple connections to the server from the same process.
multiple connections to the server from the same process.
@end itemize
@end itemize
...
@@ -4457,7 +4469,7 @@ If a connection is idle for 8 hours, the server closes the connection.
...
@@ -4457,7 +4469,7 @@ If a connection is idle for 8 hours, the server closes the connection.
@strong{Column types}
@strong{Column types}
@table @code
@table @code
@item MySQL
@item MySQL
Server
Has the following additional types (among others;
Has the following additional types (among others;
@pxref{CREATE TABLE, , @code{CREATE TABLE}}):
@pxref{CREATE TABLE, , @code{CREATE TABLE}}):
@itemize @bullet
@itemize @bullet
...
@@ -4471,7 +4483,7 @@ Has the following additional types (among others;
...
@@ -4471,7 +4483,7 @@ Has the following additional types (among others;
@code{BIGINT} type for 64-bit integers.
@code{BIGINT} type for 64-bit integers.
@end itemize
@end itemize
@item
@item
MySQL also supports
MySQL
Server
also supports
the following additional type attributes:
the following additional type attributes:
@itemize @bullet
@itemize @bullet
@item
@item
...
@@ -4505,7 +4517,7 @@ And @code{LIKE} works.
...
@@ -4505,7 +4517,7 @@ And @code{LIKE} works.
@strong{Index Creation}
@strong{Index Creation}
@table @code
@table @code
@item MySQL
@item MySQL
Server
Indexes may be specified at table creation time with the @code{CREATE TABLE}
Indexes may be specified at table creation time with the @code{CREATE TABLE}
statement.
statement.
@item mSQL
@item mSQL
...
@@ -4517,7 +4529,7 @@ Indexes must be created after the table has been created, with separate
...
@@ -4517,7 +4529,7 @@ Indexes must be created after the table has been created, with separate
@strong{To Insert a Unique Identifier into a Table}
@strong{To Insert a Unique Identifier into a Table}
@table @code
@table @code
@item MySQL
@item MySQL
Server
Use @code{AUTO_INCREMENT} as a column type
Use @code{AUTO_INCREMENT} as a column type
specifier.
specifier.
@xref{mysql_insert_id, , @code{mysql_insert_id()}}.
@xref{mysql_insert_id, , @code{mysql_insert_id()}}.
...
@@ -4529,7 +4541,7 @@ Create a @code{SEQUENCE} on a table and select the @code{_seq} column.
...
@@ -4529,7 +4541,7 @@ Create a @code{SEQUENCE} on a table and select the @code{_seq} column.
@strong{To Obtain a Unique Identifier for a Row}
@strong{To Obtain a Unique Identifier for a Row}
@table @code
@table @code
@item MySQL
@item MySQL
Server
Add a @code{PRIMARY KEY} or @code{UNIQUE} key to the table and use this.
Add a @code{PRIMARY KEY} or @code{UNIQUE} key to the table and use this.
New in Version 3.23.11: If the @code{PRIMARY} or @code{UNIQUE} key consists of only one
New in Version 3.23.11: If the @code{PRIMARY} or @code{UNIQUE} key consists of only one
column and this is of type integer, one can also refer to it as
column and this is of type integer, one can also refer to it as
...
@@ -4543,7 +4555,7 @@ depending on many factors.
...
@@ -4543,7 +4555,7 @@ depending on many factors.
@strong{To Get the Time a Column Was Last Modified}
@strong{To Get the Time a Column Was Last Modified}
@table @code
@table @code
@item MySQL
@item MySQL
Server
Add a @code{TIMESTAMP} column to the table. This column is automatically set
Add a @code{TIMESTAMP} column to the table. This column is automatically set
to the current date and time for @code{INSERT} or @code{UPDATE} statements if
to the current date and time for @code{INSERT} or @code{UPDATE} statements if
you don't give the column a value or if you give it a @code{NULL} value.
you don't give the column a value or if you give it a @code{NULL} value.
...
@@ -4556,20 +4568,20 @@ Use the @code{_timestamp} column.
...
@@ -4556,20 +4568,20 @@ Use the @code{_timestamp} column.
@strong{@code{NULL} Value Comparisons}
@strong{@code{NULL} Value Comparisons}
@table @code
@table @code
@item MySQL
@item MySQL
Server
MySQL follows
MySQL
Server
follows
ANSI SQL, and a comparison with @code{NULL} is always @code{NULL}.
ANSI SQL, and a comparison with @code{NULL} is always @code{NULL}.
@item mSQL
@item mSQL
In @code{mSQL}, @code{NULL = NULL} is TRUE. You
In @code{mSQL}, @code{NULL = NULL} is TRUE. You
must change @code{=NULL} to @code{IS NULL} and @code{<>NULL} to
must change @code{=NULL} to @code{IS NULL} and @code{<>NULL} to
@code{IS NOT NULL} when porting old code from @code{mSQL} to MySQL.
@code{IS NOT NULL} when porting old code from @code{mSQL} to MySQL
Server
.
@end table
@end table
@noindent
@noindent
@strong{String Comparisons}
@strong{String Comparisons}
@table @code
@table @code
@item MySQL
@item MySQL
Server
Normally, string comparisons are performed in case-independent fashion with
Normally, string comparisons are performed in case-independent fashion with
the sort order determined by the current character set (ISO-8859-1 Latin1 by
the sort order determined by the current character set (ISO-8859-1 Latin1 by
default). If you don't like this, declare your columns with the
default). If you don't like this, declare your columns with the
...
@@ -4584,7 +4596,7 @@ sorting in ASCII order.
...
@@ -4584,7 +4596,7 @@ sorting in ASCII order.
@strong{Case-insensitive Searching}
@strong{Case-insensitive Searching}
@table @code
@table @code
@item MySQL
@item MySQL
Server
@code{LIKE} is a case-insensitive or case-sensitive operator, depending on
@code{LIKE} is a case-insensitive or case-sensitive operator, depending on
the columns involved. If possible, MySQL uses indexes if the
the columns involved. If possible, MySQL uses indexes if the
@code{LIKE} argument doesn't start with a wild-card character.
@code{LIKE} argument doesn't start with a wild-card character.
...
@@ -4596,7 +4608,7 @@ Use @code{CLIKE}.
...
@@ -4596,7 +4608,7 @@ Use @code{CLIKE}.
@strong{Handling of Trailing Spaces}
@strong{Handling of Trailing Spaces}
@table @code
@table @code
@item MySQL
@item MySQL
Server
Strips all spaces at the end of @code{CHAR} and @code{VARCHAR}
Strips all spaces at the end of @code{CHAR} and @code{VARCHAR}
columns. Use a @code{TEXT} column if this behavior is not desired.
columns. Use a @code{TEXT} column if this behavior is not desired.
@item mSQL
@item mSQL
...
@@ -4607,20 +4619,20 @@ Retains trailing space.
...
@@ -4607,20 +4619,20 @@ Retains trailing space.
@strong{@code{WHERE} Clauses}
@strong{@code{WHERE} Clauses}
@table @code
@table @code
@item MySQL
@item MySQL
Server
MySQL correctly prioritises everything (@code{AND} is evaluated
MySQL correctly prioritises everything (@code{AND} is evaluated
before @code{OR}). To get @code{mSQL} behavior in MySQL, use
before @code{OR}). To get @code{mSQL} behavior in MySQL
Server
, use
parentheses (as shown in an example below).
parentheses (as shown in an example below).
@item mSQL
@item mSQL
Evaluates everything from left to right. This means that some logical
Evaluates everything from left to right. This means that some logical
calculations with more than three arguments cannot be expressed in any
calculations with more than three arguments cannot be expressed in any
way. It also means you must change some queries when you upgrade to
way. It also means you must change some queries when you upgrade to
MySQL. You do this easily by adding parentheses. Suppose you
MySQL
Server
. You do this easily by adding parentheses. Suppose you
have the following @code{mSQL} query:
have the following @code{mSQL} query:
@example
@example
mysql> SELECT * FROM table WHERE a=1 AND b=2 OR a=3 AND b=4;
mysql> SELECT * FROM table WHERE a=1 AND b=2 OR a=3 AND b=4;
@end example
@end example
To make MySQL evaluate this the way that @code{mSQL} would,
To make MySQL
Server
evaluate this the way that @code{mSQL} would,
you must add parentheses:
you must add parentheses:
@example
@example
mysql> SELECT * FROM table WHERE (a=1 AND (b=2 OR (a=3 AND (b=4))));
mysql> SELECT * FROM table WHERE (a=1 AND (b=2 OR (a=3 AND (b=4))));
...
@@ -4631,7 +4643,7 @@ mysql> SELECT * FROM table WHERE (a=1 AND (b=2 OR (a=3 AND (b=4))));
...
@@ -4631,7 +4643,7 @@ mysql> SELECT * FROM table WHERE (a=1 AND (b=2 OR (a=3 AND (b=4))));
@strong{Access Control}
@strong{Access Control}
@table @code
@table @code
@item MySQL
@item MySQL
Server
Has tables to store grant (permission) options per user, host, and
Has tables to store grant (permission) options per user, host, and
database. @xref{Privileges}.
database. @xref{Privileges}.
@item mSQL
@item mSQL
...
@@ -4651,17 +4663,17 @@ on making our respective database as good as possible, so we are both a
...
@@ -4651,17 +4663,17 @@ on making our respective database as good as possible, so we are both a
serious alternative to any commercial database.
serious alternative to any commercial database.
The following comparison is made by us at MySQL AB. We have tried to be
The following comparison is made by us at MySQL AB. We have tried to be
as accurate and fair as possible, but because while we know MySQL
th
rougly
as accurate and fair as possible, but because while we know MySQL
Server tho
rougly
we don't have a full knowledge of all PostgreSQL features, so we may have
we don't have a full knowledge of all PostgreSQL features, so we may have
got some things wrong. We will however correct these when they come to our
got some things wrong. We will however correct these when they come to our
attention.
attention.
We would first like to note that PostgreSQL and MySQL are both widely used
We would first like to note that PostgreSQL and MySQL
Server
are both widely used
products, but with different design goals, even if we are both striving
products, but with different design goals, even if we are both striving
towards ANSI SQL compliancy. This means that for some applications MySQL
towards ANSI SQL compliancy. This means that for some applications MySQL
Server
is more suited, while for others PostgreSQL is more suited. When choosing
is more suited, while for others PostgreSQL is more suited. When choosing
which database to use, you should first check if the database's feature set
which database to use, you should first check if the database's feature set
satisfies your application. If you need raw speed, MySQL is probably your
satisfies your application. If you need raw speed, MySQL
Server
is probably your
best choice. If you need some of the extra features that only PostgreSQL
best choice. If you need some of the extra features that only PostgreSQL
can offer, you should use @code{PostgreSQL}.
can offer, you should use @code{PostgreSQL}.
...
@@ -4676,7 +4688,7 @@ can offer, you should use @code{PostgreSQL}.
...
@@ -4676,7 +4688,7 @@ can offer, you should use @code{PostgreSQL}.
@subsubsection MySQL and PostgreSQL development strategies
@subsubsection MySQL and PostgreSQL development strategies
@cindex PostgreSQL vs. MySQL, strategies
@cindex PostgreSQL vs. MySQL, strategies
When adding things to MySQL we take pride to do an optimal, definite
When adding things to MySQL
Server
we take pride to do an optimal, definite
solution. The code should be so good that we shouldn't have any need to
solution. The code should be so good that we shouldn't have any need to
change it in the foreseeable future. We also do not like to sacrifice
change it in the foreseeable future. We also do not like to sacrifice
speed for features but instead will do our utmost to find a solution
speed for features but instead will do our utmost to find a solution
...
@@ -4696,7 +4708,7 @@ it makes sense to prioritise adding a lot of new features, instead of
...
@@ -4696,7 +4708,7 @@ it makes sense to prioritise adding a lot of new features, instead of
implementing them optimally, because one can always optimise things
implementing them optimally, because one can always optimise things
later if there arises a need for this.
later if there arises a need for this.
Another big difference between MySQL and PostgreSQL is that
Another big difference between MySQL
Server
and PostgreSQL is that
nearly all of the code in the MySQL server are coded by developers that
nearly all of the code in the MySQL server are coded by developers that
are employed by MySQL AB and are still working on the server code. The
are employed by MySQL AB and are still working on the server code. The
exceptions are the transaction engines, and the regexp library.
exceptions are the transaction engines, and the regexp library.
...
@@ -4728,23 +4740,23 @@ database. The above web page is however extremely useful when you want to
...
@@ -4728,23 +4740,23 @@ database. The above web page is however extremely useful when you want to
ensure that your applications works with many different databases or
ensure that your applications works with many different databases or
when you want to convert your application from one database to another.
when you want to convert your application from one database to another.
MySQL offers the following advantages over PostgreSQL:
MySQL
Server
offers the following advantages over PostgreSQL:
@itemize @bullet
@itemize @bullet
@item
@item
@code{MySQL} is generally much faster than PostgreSQL.
@code{MySQL}
Server
is generally much faster than PostgreSQL.
@item
@item
MySQL has a much larger user base than PostgreSQL, therefore the
MySQL has a much larger user base than PostgreSQL, therefore the
code is more tested and has historically proven more stable than
code is more tested and has historically proven more stable than
PostgreSQL. MySQL is the much more used in production
PostgreSQL. MySQL
Server
is the much more used in production
environments than PostgreSQL, mostly thanks to that MySQL AB,
environments than PostgreSQL, mostly thanks to that MySQL AB,
formerly TCX DataKonsult AB, has provided top quality commercial support
formerly TCX DataKonsult AB, has provided top quality commercial support
for MySQL from the day it was released, whereas until recently
for MySQL
Server
from the day it was released, whereas until recently
PostgreSQL was unsupported.
PostgreSQL was unsupported.
@item
@item
MySQL
works better on Windows than PostgreSQL does. MySQL
runs as a
MySQL
Server works better on Windows than PostgreSQL does. MySQL Server
runs as a
native Windows application (a service on NT/Win2000/WinXP), while
native Windows application (a service on NT/Win2000/WinXP), while
PostgreSQL is run under the @code{Cygwin} emulation. We have heard
PostgreSQL is run under the @code{Cygwin} emulation. We have heard
that PostgreSQL is not yet that stable on Windows but we haven't
that PostgreSQL is not yet that stable on Windows but we haven't
...
@@ -4755,8 +4767,8 @@ MySQL has more APIs to other languages and is supported by more
...
@@ -4755,8 +4767,8 @@ MySQL has more APIs to other languages and is supported by more
existing programs than PostgreSQL. @xref{Contrib}.
existing programs than PostgreSQL. @xref{Contrib}.
@item
@item
MySQL works on 24/7 heavy duty systems. In most circumstances
MySQL
Server
works on 24/7 heavy duty systems. In most circumstances
you never have to run any cleanups on MySQL. PostgreSQL doesn't
you never have to run any cleanups on MySQL
Server
. PostgreSQL doesn't
yet support 24/7 systems because you have to run @code{VACUUM()}
yet support 24/7 systems because you have to run @code{VACUUM()}
once in a while to reclaim space from @code{UPDATE} and @code{DELETE}
once in a while to reclaim space from @code{UPDATE} and @code{DELETE}
commands and to perform statistics analyses that are critical to get
commands and to perform statistics analyses that are critical to get
...
@@ -4782,31 +4794,31 @@ Included in the MySQL distribution are two different testing suites,
...
@@ -4782,31 +4794,31 @@ Included in the MySQL distribution are two different testing suites,
(@uref{http://www.mysql.com/information/crash-me.php}), as well
(@uref{http://www.mysql.com/information/crash-me.php}), as well
as a benchmark suite. The test system is actively updated with code to
as a benchmark suite. The test system is actively updated with code to
test each new feature and almost all reproduceable bugs that have come to
test each new feature and almost all reproduceable bugs that have come to
our attention. We test MySQL with these on a lot of platforms before
our attention. We test MySQL
Server
with these on a lot of platforms before
every release. These tests are more sophisticated than anything we have
every release. These tests are more sophisticated than anything we have
seen from PostgreSQL, and they ensures that the MySQL is kept to a high
seen from PostgreSQL, and they ensures that the MySQL
Server
is kept to a high
standard.
standard.
@item
@item
There are far more books in print about MySQL than about PostgreSQL.
There are far more books in print about MySQL
Server
than about PostgreSQL.
O'Reilly, SAMS, Que, and New Riders are all major publishers with books
O'Reilly, SAMS, Que, and New Riders are all major publishers with books
about MySQL. All MySQL features are also documented in the MySQL on-line
about MySQL. All MySQL features are also documented in the MySQL on-line
manual, because when a new feature is implemented, the MySQL developers
manual, because when a new feature is implemented, the MySQL developers
are required to document it before it's included in the source.
are required to document it before it's included in the source.
@item
@item
MySQL supports more of the standard ODBC functions than @code{PostgreSQL}.
MySQL
Server
supports more of the standard ODBC functions than @code{PostgreSQL}.
@item
@item
MySQL has a much more sophisticated @code{ALTER TABLE}.
MySQL
Server
has a much more sophisticated @code{ALTER TABLE}.
@item
@item
MySQL has support for tables without transactions for applications that
MySQL
Server
has support for tables without transactions for applications that
need all speed they can get. The tables may be memory based, @code{HEAP}
need all speed they can get. The tables may be memory based, @code{HEAP}
tables or disk based @code{MyISAM}. @xref{Table types}.
tables or disk based @code{MyISAM}. @xref{Table types}.
@item
@item
MySQL has support for two different table handlers that support
MySQL
Server
has support for two different table handlers that support
transactions, @code{InnoDB} and @code{BerkeleyDB}. Because every
transactions, @code{InnoDB} and @code{BerkeleyDB}. Because every
transaction engine performs differently under different conditions, this
transaction engine performs differently under different conditions, this
gives the application writer more options to find an optimal solution for
gives the application writer more options to find an optimal solution for
...
@@ -4825,33 +4837,33 @@ reads. This is very useful when you are archiving things.
...
@@ -4825,33 +4837,33 @@ reads. This is very useful when you are archiving things.
@xref{myisampack}.
@xref{myisampack}.
@item
@item
MySQL has internal support for fulltext search. @xref{Fulltext Search}.
MySQL
Server
has internal support for fulltext search. @xref{Fulltext Search}.
@item
@item
You can access many databases from the same connection (depending of course
You can access many databases from the same connection (depending of course
on your privileges).
on your privileges).
@item
@item
MySQL is coded from the start to be multi-threaded while PostgreSQL uses
MySQL
Server
is coded from the start to be multi-threaded while PostgreSQL uses
processes. Context switching and access to common storage areas is much
processes. Context switching and access to common storage areas is much
faster between threads than between separate processes, this gives MySQL
faster between threads than between separate processes, this gives MySQL
Server
a big speed advantage in multi-user applications and also makes it easier
a big speed advantage in multi-user applications and also makes it easier
for MySQL to take full advantage of symmetric multiprocessor (SMP) systems.
for MySQL
Server
to take full advantage of symmetric multiprocessor (SMP) systems.
@item
@item
MySQL has a much more sophisticated privilege system than PostgreSQL.
MySQL
Server
has a much more sophisticated privilege system than PostgreSQL.
While PostgreSQL only supports @code{INSERT}, @code{SELECT}, and
While PostgreSQL only supports @code{INSERT}, @code{SELECT}, and
@code{UPDATE/DELETE} grants per user on a database or a table, MySQL allows
@code{UPDATE/DELETE} grants per user on a database or a table, MySQL
Server
allows
you to define a full set of different privileges on database, table and
you to define a full set of different privileges on database, table and
column level. MySQL also allows you to specify the privilege on host and
column level. MySQL
Server
also allows you to specify the privilege on host and
user combinations. @xref{GRANT}.
user combinations. @xref{GRANT}.
@item
@item
MySQL supports a compressed client/server protocol which improves
MySQL
Server
supports a compressed client/server protocol which improves
performance over slow links.
performance over slow links.
@item
@item
MySQL employs a ``table handler'' concept, and is the only relational
MySQL
Server
employs a ``table handler'' concept, and is the only relational
database we know of built around this concept. This allows different
database we know of built around this concept. This allows different
low-level table types to be called from the SQL engine, and each table
low-level table types to be called from the SQL engine, and each table
type can be optimised for different performance characteristics.
type can be optimised for different performance characteristics.
...
@@ -4868,19 +4880,19 @@ of a data file happens, usually from a hardware failure. It allows a
...
@@ -4868,19 +4880,19 @@ of a data file happens, usually from a hardware failure. It allows a
majority of the data to be recovered.
majority of the data to be recovered.
@item
@item
Upgrading MySQL
is painless. When you are upgrading MySQL
, you don't need
Upgrading MySQL
Server is painless. When you are upgrading MySQL Server
, you don't need
to dump/restore your data, as you have to do with most PostgreSQL upgrades.
to dump/restore your data, as you have to do with most PostgreSQL upgrades.
@end itemize
@end itemize
Drawbacks with MySQL compared to PostgreSQL:
Drawbacks with MySQL
Server
compared to PostgreSQL:
@itemize @bullet
@itemize @bullet
@item
@item
The transaction support in MySQL is not yet as well tested as PostgreSQL's
The transaction support in MySQL
Server
is not yet as well tested as PostgreSQL's
system.
system.
@item
@item
Because MySQL uses threads, which are not yet flawless on many OSes, one
Because MySQL
Server
uses threads, which are not yet flawless on many OSes, one
must either use binaries from @uref{http://www.mysql.com/downloads/}, or
must either use binaries from @uref{http://www.mysql.com/downloads/}, or
carefully follow our instructions on
carefully follow our instructions on
@uref{http://www.mysql.com/doc/I/n/Installing_source.html} to get an
@uref{http://www.mysql.com/doc/I/n/Installing_source.html} to get an
...
@@ -4896,22 +4908,22 @@ application. If not, one can always switch the trouble table to use one
...
@@ -4896,22 +4908,22 @@ application. If not, one can always switch the trouble table to use one
of the transactional table types. @xref{Table locking}.
of the transactional table types. @xref{Table locking}.
@item
@item
With UDF (user defined functions) one can extend MySQL with both normal
With UDF (user defined functions) one can extend MySQL
Server
with both normal
SQL functions and aggregates, but this is not yet as easy or as flexible
SQL functions and aggregates, but this is not yet as easy or as flexible
as in PostgreSQL. @xref{Adding functions}.
as in PostgreSQL. @xref{Adding functions}.
@item
@item
Updates that run over multiple tables is harder to do in MySQL.
Updates that run over multiple tables is harder to do in MySQL
Server
.
This will, however, be fixed in MySQL 4.0 with multi-table @code{UPDATE}
This will, however, be fixed in MySQL
Server
4.0 with multi-table @code{UPDATE}
and in MySQL 4.1 with subselects.
and in MySQL
Server
4.1 with subselects.
In MySQL 4.0 one can use multi-table deletes to delete from many tables
In MySQL
Server
4.0 one can use multi-table deletes to delete from many tables
at the same time. @xref{DELETE}.
at the same time. @xref{DELETE}.
@end itemize
@end itemize
PostgreSQL currently offers the following advantages over MySQL:
PostgreSQL currently offers the following advantages over MySQL
Server
:
Note that because we know the MySQL road map, we have included in the
Note that because we know the MySQL road map, we have included in the
following table the version when MySQL should support this feature.
following table the version when MySQL
Server
should support this feature.
Unfortunately we couldn't do this for previous comparison, because we
Unfortunately we couldn't do this for previous comparison, because we
don't know the PostgreSQL roadmap.
don't know the PostgreSQL roadmap.
...
@@ -4941,7 +4953,7 @@ Standard usage in PostgreSQL is closer to ANSI SQL in some cases.
...
@@ -4941,7 +4953,7 @@ Standard usage in PostgreSQL is closer to ANSI SQL in some cases.
One can speed up PostgreSQL by coding things as stored procedures.
One can speed up PostgreSQL by coding things as stored procedures.
@item
@item
For geographical data, R-TREES makes PostgreSQL better than MySQL.
For geographical data, R-TREES makes PostgreSQL better than MySQL
Server
.
@item
@item
The PostgreSQL optimiser can do some optimisation that the current MySQL
The PostgreSQL optimiser can do some optimisation that the current MySQL
...
@@ -4956,7 +4968,7 @@ databases.
...
@@ -4956,7 +4968,7 @@ databases.
PostgreSQL has a bigger team of developers that contribute to the server.
PostgreSQL has a bigger team of developers that contribute to the server.
@end itemize
@end itemize
Drawbacks with PostgreSQL compared to MySQL:
Drawbacks with PostgreSQL compared to MySQL
Server
:
@itemize @bullet
@itemize @bullet
@item
@item
...
@@ -4979,7 +4991,7 @@ in this section.
...
@@ -4979,7 +4991,7 @@ in this section.
@cindex PostgreSQL vs. MySQL, benchmarks
@cindex PostgreSQL vs. MySQL, benchmarks
The only open source benchmark that we know of that can be used to
The only open source benchmark that we know of that can be used to
benchmark MySQL and PostgreSQL (and other databases) is our own. It can
benchmark MySQL
Server
and PostgreSQL (and other databases) is our own. It can
be found at @uref{http://www.mysql.com/information/benchmarks.html}.
be found at @uref{http://www.mysql.com/information/benchmarks.html}.
We have many times asked the PostgreSQL developers and some PostgreSQL
We have many times asked the PostgreSQL developers and some PostgreSQL
...
@@ -5023,12 +5035,12 @@ database is very good at and not testing anything that the database is
...
@@ -5023,12 +5035,12 @@ database is very good at and not testing anything that the database is
not good at. If one, after doing this, summarises the result with as
not good at. If one, after doing this, summarises the result with as
a single figure, things are even easier.
a single figure, things are even easier.
This would be like us measuring the speed of MySQL compared to PostgreSQL
This would be like us measuring the speed of MySQL
Server
compared to PostgreSQL
by looking at the summary time of the MySQL benchmarks on our web page.
by looking at the summary time of the MySQL benchmarks on our web page.
Based on this MySQL would be more than 40 times faster than PostgreSQL,
Based on this MySQL
Server
would be more than 40 times faster than PostgreSQL,
something that is of course not true. We could make things even worse
something that is of course not true. We could make things even worse
by just taking the test where PostgreSQL performs worst and claim that
by just taking the test where PostgreSQL performs worst and claim that
MySQL is more than 2000 times faster than PostgreSQL.
MySQL
Server
is more than 2000 times faster than PostgreSQL.
The case is that MySQL does a lot of optimisations that PostgreSQL
The case is that MySQL does a lot of optimisations that PostgreSQL
doesn't do. This is of course also true the other way around. An SQL
doesn't do. This is of course also true the other way around. An SQL
...
@@ -5043,7 +5055,7 @@ give you a notion about things to avoid and what you may have to do in
...
@@ -5043,7 +5055,7 @@ give you a notion about things to avoid and what you may have to do in
other ways.
other ways.
We know of two benchmark tests that claims that PostgreSQL performs better
We know of two benchmark tests that claims that PostgreSQL performs better
than MySQL. These both where multi-user tests, a test that we here at
than MySQL
Server
. These both where multi-user tests, a test that we here at
MySQL AB haven't had time to write and include in the benchmark suite,
MySQL AB haven't had time to write and include in the benchmark suite,
mainly because it's a big task to do this in a manner that is fair against
mainly because it's a big task to do this in a manner that is fair against
all databases.
all databases.
...
@@ -5101,7 +5113,7 @@ database itself.
...
@@ -5101,7 +5113,7 @@ database itself.
@item
@item
When running the database against Oracle and MS-SQL (Great Bridge has
When running the database against Oracle and MS-SQL (Great Bridge has
indirectly indicated th
at th
e databases they used in the test), they
indirectly indicated the databases they used in the test), they
didn't use the native protocol but instead ODBC. Anyone that has ever
didn't use the native protocol but instead ODBC. Anyone that has ever
used Oracle knows that all real application uses the native interface
used Oracle knows that all real application uses the native interface
instead of ODBC. Doing a test through ODBC and claiming that the results
instead of ODBC. Doing a test through ODBC and claiming that the results
...
@@ -5123,7 +5135,7 @@ doing this.
...
@@ -5123,7 +5135,7 @@ doing this.
@item
@item
After the first test, we contacted Great Bridge and mentioned to them
After the first test, we contacted Great Bridge and mentioned to them
some of the obvious mistakes they had done with MySQL:
some of the obvious mistakes they had done with MySQL
Server
:
@itemize @minus
@itemize @minus
@item
@item
...
@@ -5136,12 +5148,12 @@ Running on a Linux system that wasn't optimised for threads
...
@@ -5136,12 +5148,12 @@ Running on a Linux system that wasn't optimised for threads
Using an old MySQL version when there was a recommended newer one available
Using an old MySQL version when there was a recommended newer one available
@item
@item
Not starting MySQL with the right options for heavy multi-user use (the
Not starting MySQL
Server
with the right options for heavy multi-user use (the
default installation of MySQL is tuned for minimal resource use).
default installation of MySQL
Server
is tuned for minimal resource use).
@end itemize
@end itemize
Great Bridge did run a new test, with our optimised ODBC driver and with
Great Bridge did run a new test, with our optimised ODBC driver and with
better startup options for MySQL, but refused to either use our updated
better startup options for MySQL
Server
, but refused to either use our updated
glibc library or our standard binary (used by 80% of our users), which was
glibc library or our standard binary (used by 80% of our users), which was
statically linked with a fixed glibc library.
statically linked with a fixed glibc library.
...
@@ -5161,9 +5173,9 @@ published a comparison on PHPbuilder
...
@@ -5161,9 +5173,9 @@ published a comparison on PHPbuilder
When we became aware of the comparison, we phoned Tim Perdue about this
When we became aware of the comparison, we phoned Tim Perdue about this
because there were a lot of strange things in his results. For example,
because there were a lot of strange things in his results. For example,
he claimed that MySQL had a problem with five users in his tests, when we
he claimed that MySQL
Server
had a problem with five users in his tests, when we
know that there are users with similar machines as his that are using
know that there are users with similar machines as his that are using
MySQL with 2000 simultaneous connections doing 400 queries per second.
MySQL
Server
with 2000 simultaneous connections doing 400 queries per second.
(In this case the limit was the web bandwidth, not the database.)
(In this case the limit was the web bandwidth, not the database.)
It sounded like he was using a Linux kernel that either had some
It sounded like he was using a Linux kernel that either had some
...
@@ -5185,10 +5197,10 @@ He has not done that yet.
...
@@ -5185,10 +5197,10 @@ He has not done that yet.
Because of this we can't put any trust in this benchmark either :(
Because of this we can't put any trust in this benchmark either :(
Over time things also changes and the above benchmarks are not that
Over time things also changes and the above benchmarks are not that
relevant anymore. MySQL
now have
a couple of different table handlers
relevant anymore. MySQL
Server now has
a couple of different table handlers
with different speed/concurrency tradeoffs. @xref{Table types}. It
with different speed/concurrency tradeoffs. @xref{Table types}. It
would be interesting to see how the above tests would run with the
would be interesting to see how the above tests would run with the
different transactional table types in MySQL. PostgreSQL has of course
different transactional table types in MySQL
Server
. PostgreSQL has of course
also got new features since the test was made. As the above test are
also got new features since the test was made. As the above test are
not publicly available there is no way for us to know how the
not publicly available there is no way for us to know how the
database would preform in the same tests today.
database would preform in the same tests today.
...
@@ -5197,7 +5209,8 @@ database would preform in the same tests today.
...
@@ -5197,7 +5209,8 @@ database would preform in the same tests today.
Conclusion:
Conclusion:
The only benchmarks that exist today that anyone can download and run
The only benchmarks that exist today that anyone can download and run
against MySQL and PostgreSQL is the MySQL benchmarks. We here at MySQL
against MySQL Server and PostgreSQL is the MySQL benchmarks.
We here at MySQL AB
believe that open source databases should be tested with open source tools!
believe that open source databases should be tested with open source tools!
This is the only way to ensure that no one does tests that nobody can
This is the only way to ensure that no one does tests that nobody can
reproduce and use this to claim that a database is better than another.
reproduce and use this to claim that a database is better than another.
...
@@ -5208,7 +5221,7 @@ The thing we find strange is that every test we have seen about
...
@@ -5208,7 +5221,7 @@ The thing we find strange is that every test we have seen about
PostgreSQL, that is impossible to reproduce, claims that PostgreSQL is
PostgreSQL, that is impossible to reproduce, claims that PostgreSQL is
better in most cases while our tests, which anyone can reproduce,
better in most cases while our tests, which anyone can reproduce,
clearly shows otherwise. With this we don't want to say that PostgreSQL
clearly shows otherwise. With this we don't want to say that PostgreSQL
isn't good at many things (it is!) or that it isn't faster than MySQL
isn't good at many things (it is!) or that it isn't faster than MySQL
Server
under certain conditions. We would just like to see a fair test where
under certain conditions. We would just like to see a fair test where
they are very good so that we could get some friendly competition going!
they are very good so that we could get some friendly competition going!
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment