This release of MySQL has two known outstanding issues for Windows:
.msi installer does not detect an
root password on the initial
configuration attempt. To work around this, install and
configure MySQL as normal, but skip any changes to security.
(There is a check box that enables this on the security
screen of the configuration wizard.) Then check your
If the old
root password and security
settings are okay, you are done and can proceed to use
Otherwise, reconfigure with the wizard and make any
changes on the second configuration attempt. The wizard
will properly prompt for the existing
root password and permit changes to
This issue has been filed as Bug #45200 for correction in a future release.
The Windows configuration wizard permits changes to
InnoDB settings during a reconfiguration
operation. For an upgrade, this may cause difficulties. To
work around this, use one of the following alternatives:
Do not change
Copy files from the old
location to the new one.
This issue has been filed as Bug #45201 for correction in a future release.
If the character set for a column being compared was neither the
default server character set nor
InnoDB was slower than necessary due to
excessive contention for a character set mutex.
As a workaround for earlier versions, set the default server
character set to the character set other than
latin1 that is most often used in indexed
InnoDB uses random numbers to
generate dives into indexes for calculating index cardinality.
However, under certain conditions, the algorithm did not
generate random numbers, so
TABLE did not update cardinality estimates properly. A
new algorithm has been introduced with better randomization
properties, together with a system variable,
that controls which algorithm to use. The default value of the
variable is 1 (
ON), to use the original
algorithm for compatibility with existing applications. The
variable can be set to 0 (
OFF) to use the new
algorithm with improved randomness.
Important Change; Replication:
The transactional behavior of
SLAVE has changed. Formerly, it took effect
immediately, even inside a transaction; now, it waits until the
current replication event group (if any) has finished executing,
or until the user issues a
KILL QUERY or
This was done to solve the problem encountered when replication
was stopped while a nontransactional slave was replicating a
transaction on the master. (It was impossible to roll back a
mixed-engines transaction when one of the engines was
nontransactional, which meant that the slave could not safely
re-apply any transaction that had been interrupted by
(Bug #319, Bug #38205)
References: See also Bug #43217.
When a value was equal to a
PARTITION ... VALUES LESS
THAN ( value other
MAXVALUE, the corresponding partition
was not pruned.
Unrelated errors occurring during the execution of
RESET SLAVE could cause the slave
had no effect when using row-based logging format.
Replication: The following errors were not correctly reported:
Failures during slave thread initialization
Failures while initializing the relay log position (immediately following the starting of the slave thread)
Failures while processing queries passed through the
Information about these types of failures can now be found in
the output of
Replication: Killing the thread executing a DDL statement, after it had finished its execution but before it had written the binlog event, caused the error code in the binlog event to be set (incorrectly) to ER_SERVER_SHUTDOWN or ER_QUERY_INTERRUPTED, which caused replication to fail. (Bug #37145)
References: See also Bug #27571, Bug #22725.
Replication: Column aliases used inside subqueries were ignored in the binary log. (Bug #35515)
MySQL Server permitted the creation of a merge table based on views but crashed when attempts were made to read from that table. The following example demonstrates this:
#Create a test table CREATE TABLE tmp (id int, c char(2)); #Create two VIEWs upon it CREATE VIEW v1 AS SELECT * FROM tmp; CREATE VIEW v2 AS SELECT * FROM tmp; #Finally create a MERGE table upon the VIEWs CREATE TABLE merge (id int, c char(2)) ENGINE=MERGE UNION(v1, v2); #Reading from the merge table lead to a crash SELECT * FROM merge;
The final statement generated the crash. (Bug #44040)
utf8_swedish_ci collations did not work with
indexes using the
IBMDB2I storage engine.
Support is now provided for MySQL when running on IBM i 6.1 or
Some schema names longer than 8 characters were not supported by
IBMDB2I. The engine has been updated to
permit digits and underscore characters to be used in names
longer than 8 characters.
In some circumstances, when a table is created with the
IBMDB2I engine, the
TABLE statement will return successfully but the table
will not exist.
Using an XML function such as
ExtractValue() more than once in
a single query could produce erroneous results.
References: See also Bug #43937.
For some queries, an equality propagation problem could cause
a = b and
b = a to be
CHECK TABLE did not properly
MyISAM tables created by
servers from MySQL 4.0 or older needed to be upgraded. This
could cause problems upgrading to MySQL 5.1 or higher.
On Windows, running the server with
myisam_use_mmap enabled caused
MyISAM table corruption.
A stored routine contain a C-style comment could not be dumped and reloaded. (Bug #39559)
IGNORE statement involving a foreign key constraint
caused an assertion failure.
The mysql_setpermission operation for removing database privileges removed global privileges instead. (Bug #39852)
For shared-memory connections, the read and write methods did
not properly handle asynchronous close events, which could lead
to the client locking up waiting for a server response. For
example, a call to
mysql_real_query() would block
forever on the client side if the executed statement was aborted
on the server side. Thanks to Armin Schöffmann for the bug
report and patch.
did not properly activate triggers.
DELETE through a secondary index,
InnoDB did not store the cursor position.
InnoDB crash in semi-consistent
read while attempting to unlock a nonmatching record.
Compressing a table with the myisampack utility caused the server to produce Valgrind warnings when it opened the table. (Bug #41541)
MyISAM table with
DELAY_KEY_WRITE enabled, the index file could
be corrupted without the table being marked as crashed if the
server was killed.
... SELECT statement for a
table could cause table corruption if the table had indexes.
Incomplete cleanup of
the filesort of rows for a
GROUP BY clause
inside a subquery caused a server crash.
Incorrect elevation of warning messages to error messages for unsafe statements caused a server crash. (Bug #42640)
... UPGRADE DATA DIRECTORY NAME failed when the
database contained views.
UNION of floating-point numbers
did unnecessary rounding.
Certain statements might open a table and then wait for an
impending global read lock without noticing whether they hold a
table being waiting for by the global read lock, causing a hang.
Affected statements are
SELECT ... FOR
LOCK TABLES ...
Incorrect initialization of
indexes could cause incorrect query results.
libmysqld crashed when it was reinitialized.
(Bug #43706, Bug #44091)
On Windows, entries for build-vs9.bat and
build-vs9_x64.bat were missing in
Full-text prefix searches could hang the connection and cause 100% CPU consumption. (Bug #42907)
On 64-bit systems, a
key_buffer_size value larger
than 4GB could couse
MyISAM index corruption.
myisamchk could display a negative
Max keyfile length value.
SHOW TABLE STATUS from
within a stored procedure could cause a
Packets out of
Not all lock types had proper descriptive strings, resulting in garbage output from mysqladmin debug. (Bug #44164)
On Windows, a server crash occurred for attempts to insert a
floating-point value into a
column with a maximum length less than the converted
floating-point value length.
The functions listed in Creating Geometry Values Using MySQL-Specific Functions, previously accepted WKB arguments and returned WKB values. They now accept WKB or geometry arguments and return geometry values.
The functions listed in Creating Geometry Values Using WKB Functions, previously accepted WKB arguments and returned geometry values. They now accept WKB or geometry arguments and return geometry values. (Bug #38990)
mysqld_multi incorrectly passed
InnoDB tables that have their own
.ibd tablespace file, a superfluous
ibuf cursor restoration fails! message could
be written to the error log. This warning has been suppressed.
Several memory allocation functions were not being checked for out-of-memory return values. (Bug #25058)
COMMIT did not delete savepoints
if there were no changes in the transaction.
myisamchk and myisampack
were not being linked with the library that enabled support for
* file name pattern expansion.