MySQL Community Server 5.1.46 has been released

MySQL Community Server 5.1.46 has been released

am 23.04.2010 19:03:27 von Karen Langford

Dear MySQL users,

MySQL Community Server 5.1.46, a new version of the popular Open
Source Database Management System, has been released. MySQL 5.1.46 is
recommended for use on production systems.

For an overview of what's new in MySQL 5.1, please see

http://dev.mysql.com/doc/refman/5.1/en/mysql-nutshell.html

For information on installing MySQL 5.1.46 on new servers or upgrading
to MySQL 5.1.46 from previous MySQL releases, please see

http://dev.mysql.com/doc/refman/5.1/en/installing.html

MySQL Server is available in source and binary form for a number of
platforms from our download pages at

http://dev.mysql.com/downloads/

Not all mirror sites may be up to date at this point in time, so if
you can't find this version on some mirror, please try again later or
choose another download site.

We welcome and appreciate your feedback, bug reports, bug fixes,
patches, etc.:

http://forge.mysql.com/wiki/Contributing

For information on open issues in MySQL 5.1, please see the errata
list at

http://dev.mysql.com/doc/refman/5.1/en/open-bugs.html

The following section lists the changes in the MySQL source code since
the previous released version of MySQL 5.1. It may also be viewed
online at

http://dev.mysql.com/doc/refman/5.1/en/news-5-1-46.html

Enjoy!

============================================================ ===========
C.1.2. Changes in MySQL 5.1.46

InnoDB Plugin Notes:

* InnoDB Plugin has been upgraded to version 1.0.7. This version
is considered of General Availability (GA) quality. The InnoDB
Plugin Change History
(http://www.innodb.com/doc/innodb_plugin-1.0/innodb-changes. ht
ml) may contain information in addition to those changes
reported here.
In this release, the InnoDB Plugin is included in source and
binary distributions, except RHEL3, RHEL4, SuSE 9 (x86,
x86_64, ia64), and generic Linux RPM packages. It also does
not work for FreeBSD 6 and HP-UX or for Linux on generic ia64.

Functionality added or changed:

* There is a new system variable, skip_name_resolve, that is set
from the value of the --skip-name-resolve server option. This
provides a way to determine at runtime whether the server uses
name resolution for client connections.
(Bug#37168: http://bugs.mysql.com/bug.php?id=37168)

Bugs fixed:

* Security Fix: Privilege checking for UNINSTALL PLUGIN was
incorrect. (Bug#51770: http://bugs.mysql.com/bug.php?id=51770)

* Partitioning: Partition pruning on RANGE partitioned tables
did not always work correctly; the last partition was not
excluded if the range was beyond it (when not using MAXVALUE).
Now the last partition is not included if the partitioning
function value is not within the range.
(Bug#51830: http://bugs.mysql.com/bug.php?id=51830)

* Partitioning: The insert_id server system variable was not
reset following an insert that failed on a partitioned MyISAM
table having an AUTO_INCREMENT column.
(Bug#50392: http://bugs.mysql.com/bug.php?id=50392)

* Partitioning: Foreign keys are not supported on partitioned
tables. However, it was possible via an ALTER TABLE statement
to set a foreign key on a partitioned table; it was also
possible to partition a table with a single foreign key.
(Bug#50104: http://bugs.mysql.com/bug.php?id=50104)

* Partitioning: GROUP BY queries performed poorly for some
partitioned tables. This was due to the block size not being
set for partitioned tables, thus the keys per block was not
correct, which could cause such queries to be optimized
incorrectly.
(Bug#48229: http://bugs.mysql.com/bug.php?id=48229)
See also Bug#37252: http://bugs.mysql.com/bug.php?id=37252.

* Partitioning: REPAIR TABLE failed for partitioned ARCHIVE
tables. (Bug#46565: http://bugs.mysql.com/bug.php?id=46565)

* Replication: TRUNCATE TABLE performed on a temporary table
using the InnoDB storage engine was logged even when using
row-based mode.
(Bug#51251: http://bugs.mysql.com/bug.php?id=51251)

* Replication: When using temporary tables the binary log needs
to insert a pseudo-thread ID for threads that are using
temporary tables, each time a switch happens between two
threads, both of which are using temporary tables. However, if
a thread issued a failing statement before exit, its ID was
not recorded in the binary log, and this in turn caused the ID
for the next thread that tried to do something with a
temporary table not to be logged as well. Subsequent replays
of the binary log failed with the error Table ... doesn't
exist. (Bug#51226: http://bugs.mysql.com/bug.php?id=51226)

* Replication: If the master was using sql_mode='TRADITIONAL',
duplicate key errors were not sent to the slave, which
received 0 rather than the expected error code. This caused
replication to fail even when such an error was expected.
(Bug#51055: http://bugs.mysql.com/bug.php?id=51055)

* Replication: When run with the --database option, mysqlbinlog
printed ROLLBACK statements but did not print any
corresponding SAVEPOINT statements.
(Bug#50407: http://bugs.mysql.com/bug.php?id=50407)

* Replication: CREATE EVENT statements were padded with
"garbage" characters when written to the binary log, which
caused a syntax error when trying to read back from the log.
(Bug#50095: http://bugs.mysql.com/bug.php?id=50095)

* Replication: Column length information generated by InnoDB did
not match that generated by MyISAM, which caused invalid
metadata to be written to the binary log when trying to
replicate BIT columns.
(Bug#49618: http://bugs.mysql.com/bug.php?id=49618)

* Replication: The value of Slave_IO_running in the output of
SHOW SLAVE STATUS did not distinguish between all 3 possible
states of the slave I/O thread (not running; running but not
connected; connected). Now the value Connecting (rather than
No) is shown when the slave I/O thread is running but the
slave is not connected to a replication master.
The server system variable Slave_running also reflects this
change, and is now consistent with what is shown for
Slave_IO_running.
(Bug#30703: http://bugs.mysql.com/bug.php?id=30703,
Bug#41613: http://bugs.mysql.com/bug.php?id=41613,
Bug#51089: http://bugs.mysql.com/bug.php?id=51089)

* EXPLAIN EXTENDED crashed trying to resolve references to freed
temporary table columns for GROUP_CONCAT() ORDER BY arguments.
(Bug#52397: http://bugs.mysql.com/bug.php?id=52397)

* For InnoDB Plugin, bit fields were causing problems with
concurrency on SMP systems because of word-packing issues.
(Bug#52360: http://bugs.mysql.com/bug.php?id=52360)

* The optimizer could attempt to evaluate the WHERE clause
before any rows had been read, resulting in a server crash.
(Bug#52177: http://bugs.mysql.com/bug.php?id=52177)

* For LDML-defined collations, some data structures were not
initialized properly to enable UPPER() and LOWER() to work
correctly. (Bug#51976: http://bugs.mysql.com/bug.php?id=51976)

* On Windows, LOAD_FILE() could cause a crash for some
pathnames. (Bug#51893: http://bugs.mysql.com/bug.php?id=51893)

* Invalid memory reads occurred for HANDLER ... READ NEXT after
a failed HANDLER ... READ FIRST.
(Bug#51877: http://bugs.mysql.com/bug.php?id=51877)

* After TRUNCATE TABLE of a MyISAM table, subsequent queries
could crash the server if myisam_use_mmap was enabled.
(Bug#51868: http://bugs.mysql.com/bug.php?id=51868)

* If myisam_sort_buffer_size was set to a small value, table
repair for MyISAM tables with FULLTEXT indexes could crash the
server. (Bug#51866: http://bugs.mysql.com/bug.php?id=51866)

* In LOAD DATA INFILE, using a SET clause to set a column equal
to itself caused a server crash.
(Bug#51850: http://bugs.mysql.com/bug.php?id=51850)

* A problem with equality propagation optimization for prepared
statements and stored procedures caused a server crash upon
re-execution of the prepared statement or stored procedure.
(Bug#51650: http://bugs.mysql.com/bug.php?id=51650)
See also Bug#8115: http://bugs.mysql.com/bug.php?id=8115,
Bug#8849: http://bugs.mysql.com/bug.php?id=8849.

* The optimizer performed an incorrect join type when COALESCE()
appeared within an IN() operation.
(Bug#51598: http://bugs.mysql.com/bug.php?id=51598)

* The server crashed when the optimizer attempted to determine
constant tables but a table storage engine did not support
exact record count.
(Bug#51494: http://bugs.mysql.com/bug.php?id=51494)

* The server could crash populating the
INFORMATION_SCHEMA.PROCESSLIST table due to lack of mutex
protection.
(Bug#51377: http://bugs.mysql.com/bug.php?id=51377)

* Use of HANDLER statements with tables that had spatial indexes
caused a server crash.
(Bug#51357: http://bugs.mysql.com/bug.php?id=51357)

* With an XA transaction active, SET autocommit = 1 could cause
side effects such as memory corruption or a server crash.
(Bug#51342: http://bugs.mysql.com/bug.php?id=51342)

* Following a bulk insert into a MyISAM table, if MyISAM failed
to build indexes using repair by sort, data file corruption
could occur.
(Bug#51307: http://bugs.mysql.com/bug.php?id=51307)

* CHECKSUM TABLE could compute the checksum for BIT columns
incorrectly.
(Bug#51304: http://bugs.mysql.com/bug.php?id=51304)

* A HAVING clause on a joined table in some cases failed to
eliminate rows which should have been excluded from the result
set. (Bug#51242: http://bugs.mysql.com/bug.php?id=51242)

* The type inference used for view columns caused some columns
in views to be handled as the wrong type, as compared to the
same columns in base tables. DATE columns in base tables were
treated as TIME columns in views, and base table TIME columns
as view DATETIME columns.
(Bug#50918: http://bugs.mysql.com/bug.php?id=50918)

* The YEAR values 2000 and 0000 could be treated as equal.
(Bug#49910: http://bugs.mysql.com/bug.php?id=49910)

* Performing a single in-place ALTER TABLE containing ADD INDEX
and DROP INDEX options that used the same index name could
result in a corrupt table definition file. Now such ALTER
TABLE statements are no longer performed in place.
(Bug#49838: http://bugs.mysql.com/bug.php?id=49838)

* mysql_upgrade did not detect when CSV log tables incorrectly
contained columns that could be NULL. Now these columns are
altered to be NOT NULL.
(Bug#49823: http://bugs.mysql.com/bug.php?id=49823)

* If a stored function contained a RETURN statement with an ENUM
value in the ucs2 character set, SHOW CREATE FUNCTION and
SELECT DTD_IDENTIFIER FROM INFORMATION_SCHEMA.ROUTINES
returned incorrect values.
(Bug#48766: http://bugs.mysql.com/bug.php?id=48766)

* The server crashed when it could not determine the best
execution plan for queries involving outer joins with
nondeterministic ON clauses such as the ones containing the
RAND() function, a user-defined function, or a NOT
DETERMINISTIC stored function.
(Bug#48483: http://bugs.mysql.com/bug.php?id=48483)

* A query that read from a derived table (of the form SELECT ...
FROM (SELECT ...)) produced incorrect results when the
following conditions were present:

+ The table subquery contained a derived query ((SELECT ...
) AS column).

+ The derived query could potentially produce zero rows or
a single NULL (that is, no rows matched, or the query
used an aggregate function such as SUM() running over
zero rows).

+ The table subquery joined at least two tables.

+ The join condition involved an index.
(Bug#47904: http://bugs.mysql.com/bug.php?id=47904)

* The optimization to read MIN() or MAX() values from an index
did not properly handle comparisons with NULL values. This
could produce incorrect results for MIN() or MAX()when the
WHERE clause tested a NOT NULL column for NULL.
(Bug#47762: http://bugs.mysql.com/bug.php?id=47762)

* Killing a query during the optimization phase of a subquery
could cause a server crash.
(Bug#47761: http://bugs.mysql.com/bug.php?id=47761)

* The query shown by EXPLAIN EXTENDED plus SHOW WARNINGS could
produce results different from the original query.
(Bug#47669: http://bugs.mysql.com/bug.php?id=47669)

* Renaming a column of an InnoDB table caused the server to go
out of sync with the InnoDB data dictionary.
(Bug#47621: http://bugs.mysql.com/bug.php?id=47621)

* MyISAM could write uninitialized data to new index pages. Now
zeros are written to unused bytes in the pages.
(Bug#47598: http://bugs.mysql.com/bug.php?id=47598)

* Setting myisam_repair_threads larger than 1 could result in
the cardinality for all indexes of a MyISAM table being set to
1 after parallel index repair.
(Bug#47444: http://bugs.mysql.com/bug.php?id=47444)

* In debug builds, if the listed columns in the view definition
of the table used in an INSERT ... SELECT statement
mismatched, an assertion was raised in the query cache
invalidation code following the failing statement.
(Bug#46615: http://bugs.mysql.com/bug.php?id=46615)

* For a query that selected from a view and used an alias for
the view, the metadata used the alias name rather than the
view name in the MYSQL_FIELD.table member.
(Bug#41788: http://bugs.mysql.com/bug.php?id=41788)

* mysql_upgrade did not create temporary files properly.
(Bug#41057: http://bugs.mysql.com/bug.php?id=41057)

* It was possible for DROP TABLE of one MyISAM table to remove
the data and index files of a different MyISAM table.
(Bug#40980: http://bugs.mysql.com/bug.php?id=40980)

* If the arguments to a CONCAT() call included a local routine
variable, selecting the return value into a user variable
could produce an incorrect result.
(Bug#40625: http://bugs.mysql.com/bug.php?id=40625)

* SHOW CREATE VIEW returned invalid SQL if the definition
contained a SELECT 'string' statement where the string was
longer than the maximum length of a column name, due to the
fact that this text was also used as an alias (in the AS
clause).
Because not all names retrieved from arbitrary SELECT
statements can be used as view column names due to length and
format restrictions, the server now checks the conformity of
automatically generated column names and rewrites according to
a predefined format any names that are not acceptable as view
column names before storing the final view definition on disk.
In such cases, the name is now rewritten as Name_exp_pos,
where pos is the position of the column. To avoid this
conversion scheme, define explicit, valid names for view
columns using the column_list clause of the CREATE VIEW
statement.
As part of this fix, aliases are now generated only for
top-level statements.
(Bug#40277: http://bugs.mysql.com/bug.php?id=40277)

* While looking for the shortest index for a covering index
scan, the optimizer ignored that a clustered primary key read
the entire table.
(Bug#39653: http://bugs.mysql.com/bug.php?id=39653)

* mysqlbinlog had a memory leak in its option-processing code.
(Bug#38468: http://bugs.mysql.com/bug.php?id=38468)

* The test for readline during configuration failed when trying
to build MySQL in a directory other than the source tree root.
(Bug#35250: http://bugs.mysql.com/bug.php?id=35250)

Thanks,
MySQL RE Team

Hery Ramilison, Karen Langford, MySQL Release Engineers
Database Group, Oracle.


--
MySQL General Mailing List
For list archives: http://lists.mysql.com/mysql
To unsubscribe: http://lists.mysql.com/mysql?unsub=gcdmg-mysql-2@m.gmane.org

Re: MySQL Community Server 5.1.46 has been released

am 23.04.2010 20:45:02 von Rob Wultsch

On Fri, Apr 23, 2010 at 10:03 AM, Karen Langford
wrote:
> Dear MySQL users,
>
> MySQL Community Server 5.1.46, a new version of the popular Open
> Source Database Management System, has been released. =A0MySQL 5.1.46 is
> recommended for use on production systems.
>
> For an overview of what's new in MySQL 5.1, please see
>
> http://dev.mysql.com/doc/refman/5.1/en/mysql-nutshell.html
>
> For information on installing MySQL 5.1.46 on new servers or upgrading
> to MySQL 5.1.46 from previous MySQL releases, please see
>
> http://dev.mysql.com/doc/refman/5.1/en/installing.html
>
> MySQL Server is available in source and binary form for a number of
> platforms from our download pages at
>
> http://dev.mysql.com/downloads/
>
> Not all mirror sites may be up to date at this point in time, so if
> you can't find this version on some mirror, please try again later or
> choose another download site.
>
> We welcome and appreciate your feedback, bug reports, bug fixes,
> patches, etc.:
>
> http://forge.mysql.com/wiki/Contributing
>
> For information on open issues in MySQL 5.1, please see the errata
> list at
>
> http://dev.mysql.com/doc/refman/5.1/en/open-bugs.html
>
> The following section lists the changes in the MySQL source code since
> the previous released version of MySQL 5.1. =A0It may also be viewed
> online at
>
> http://dev.mysql.com/doc/refman/5.1/en/news-5-1-46.html
>
> Enjoy!
>
> ==================== =====
==================== =====3D=
==================== ==
> C.1.2. Changes in MySQL 5.1.46
>
> =A0 InnoDB Plugin Notes:
>
> =A0 =A0 * InnoDB Plugin has been upgraded to version 1.0.7. This version
> =A0 =A0 =A0 is considered of General Availability (GA) quality. The InnoD=
B
> =A0 =A0 =A0 Plugin Change History
> =A0 =A0 =A0 (http://www.innodb.com/doc/innodb_plugin-1.0/innodb-changes. h=
t
> =A0 =A0 =A0 ml) may contain information in addition to those changes
> =A0 =A0 =A0 reported here.
> =A0 =A0 =A0 In this release, the InnoDB Plugin is included in source and
> =A0 =A0 =A0 binary distributions, except RHEL3, RHEL4, SuSE 9 (x86,
> =A0 =A0 =A0 x86_64, ia64), and generic Linux RPM packages. It also does
> =A0 =A0 =A0 not work for FreeBSD 6 and HP-UX or for Linux on generic ia64=
..
>
> =A0 Functionality added or changed:
>
> =A0 =A0 * There is a new system variable, skip_name_resolve, that is set
> =A0 =A0 =A0 from the value of the --skip-name-resolve server option. This
> =A0 =A0 =A0 provides a way to determine at runtime whether the server use=
s
> =A0 =A0 =A0 name resolution for client connections.
> =A0 =A0 =A0 (Bug#37168: http://bugs.mysql.com/bug.php?id=3D37168)
>
> =A0 Bugs fixed:
>
> =A0 =A0 * Security Fix: Privilege checking for UNINSTALL PLUGIN was
> =A0 =A0 =A0 incorrect. (Bug#51770: http://bugs.mysql.com/bug.php?id=3D517=
70)
>
> =A0 =A0 * Partitioning: Partition pruning on RANGE partitioned tables
> =A0 =A0 =A0 did not always work correctly; the last partition was not
> =A0 =A0 =A0 excluded if the range was beyond it (when not using MAXVALUE)=
..
> =A0 =A0 =A0 Now the last partition is not included if the partitioning
> =A0 =A0 =A0 function value is not within the range.
> =A0 =A0 =A0 (Bug#51830: http://bugs.mysql.com/bug.php?id=3D51830)
>
> =A0 =A0 * Partitioning: The insert_id server system variable was not
> =A0 =A0 =A0 reset following an insert that failed on a partitioned MyISAM
> =A0 =A0 =A0 table having an AUTO_INCREMENT column.
> =A0 =A0 =A0 (Bug#50392: http://bugs.mysql.com/bug.php?id=3D50392)
>
> =A0 =A0 * Partitioning: Foreign keys are not supported on partitioned
> =A0 =A0 =A0 tables. However, it was possible via an ALTER TABLE statement
> =A0 =A0 =A0 to set a foreign key on a partitioned table; it was also
> =A0 =A0 =A0 possible to partition a table with a single foreign key.
> =A0 =A0 =A0 (Bug#50104: http://bugs.mysql.com/bug.php?id=3D50104)
>
> =A0 =A0 * Partitioning: GROUP BY queries performed poorly for some
> =A0 =A0 =A0 partitioned tables. This was due to the block size not being
> =A0 =A0 =A0 set for partitioned tables, thus the keys per block was not
> =A0 =A0 =A0 correct, which could cause such queries to be optimized
> =A0 =A0 =A0 incorrectly.
> =A0 =A0 =A0 (Bug#48229: http://bugs.mysql.com/bug.php?id=3D48229)
> =A0 =A0 =A0 See also Bug#37252: http://bugs.mysql.com/bug.php?id=3D37252.
>
> =A0 =A0 * Partitioning: REPAIR TABLE failed for partitioned ARCHIVE
> =A0 =A0 =A0 tables. (Bug#46565: http://bugs.mysql.com/bug.php?id=3D46565)
>
> =A0 =A0 * Replication: TRUNCATE TABLE performed on a temporary table
> =A0 =A0 =A0 using the InnoDB storage engine was logged even when using
> =A0 =A0 =A0 row-based mode.
> =A0 =A0 =A0 (Bug#51251: http://bugs.mysql.com/bug.php?id=3D51251)
>
> =A0 =A0 * Replication: When using temporary tables the binary log needs
> =A0 =A0 =A0 to insert a pseudo-thread ID for threads that are using
> =A0 =A0 =A0 temporary tables, each time a switch happens between two
> =A0 =A0 =A0 threads, both of which are using temporary tables. However, i=
f
> =A0 =A0 =A0 a thread issued a failing statement before exit, its ID was
> =A0 =A0 =A0 not recorded in the binary log, and this in turn caused the I=
D
> =A0 =A0 =A0 for the next thread that tried to do something with a
> =A0 =A0 =A0 temporary table not to be logged as well. Subsequent replays
> =A0 =A0 =A0 of the binary log failed with the error Table ... doesn't
> =A0 =A0 =A0 exist. (Bug#51226: http://bugs.mysql.com/bug.php?id=3D51226)
>
> =A0 =A0 * Replication: If the master was using sql_mode=3D'TRADITIONAL',
> =A0 =A0 =A0 duplicate key errors were not sent to the slave, which
> =A0 =A0 =A0 received 0 rather than the expected error code. This caused
> =A0 =A0 =A0 replication to fail even when such an error was expected.
> =A0 =A0 =A0 (Bug#51055: http://bugs.mysql.com/bug.php?id=3D51055)
>
> =A0 =A0 * Replication: When run with the --database option, mysqlbinlog
> =A0 =A0 =A0 printed ROLLBACK statements but did not print any
> =A0 =A0 =A0 corresponding SAVEPOINT statements.
> =A0 =A0 =A0 (Bug#50407: http://bugs.mysql.com/bug.php?id=3D50407)
>
> =A0 =A0 * Replication: CREATE EVENT statements were padded with
> =A0 =A0 =A0 "garbage" characters when written to the binary log, which
> =A0 =A0 =A0 caused a syntax error when trying to read back from the log.
> =A0 =A0 =A0 (Bug#50095: http://bugs.mysql.com/bug.php?id=3D50095)
>
> =A0 =A0 * Replication: Column length information generated by InnoDB did
> =A0 =A0 =A0 not match that generated by MyISAM, which caused invalid
> =A0 =A0 =A0 metadata to be written to the binary log when trying to
> =A0 =A0 =A0 replicate BIT columns.
> =A0 =A0 =A0 (Bug#49618: http://bugs.mysql.com/bug.php?id=3D49618)
>
> =A0 =A0 * Replication: The value of Slave_IO_running in the output of
> =A0 =A0 =A0 SHOW SLAVE STATUS did not distinguish between all 3 possible
> =A0 =A0 =A0 states of the slave I/O thread (not running; running but not
> =A0 =A0 =A0 connected; connected). Now the value Connecting (rather than
> =A0 =A0 =A0 No) is shown when the slave I/O thread is running but the
> =A0 =A0 =A0 slave is not connected to a replication master.
> =A0 =A0 =A0 The server system variable Slave_running also reflects this
> =A0 =A0 =A0 change, and is now consistent with what is shown for
> =A0 =A0 =A0 Slave_IO_running.
> =A0 =A0 =A0 (Bug#30703: http://bugs.mysql.com/bug.php?id=3D30703,
> =A0 =A0 =A0 Bug#41613: http://bugs.mysql.com/bug.php?id=3D41613,
> =A0 =A0 =A0 Bug#51089: http://bugs.mysql.com/bug.php?id=3D51089)
>
> =A0 =A0 * EXPLAIN EXTENDED crashed trying to resolve references to freed
> =A0 =A0 =A0 temporary table columns for GROUP_CONCAT() ORDER BY arguments=
..
> =A0 =A0 =A0 (Bug#52397: http://bugs.mysql.com/bug.php?id=3D52397)
>
> =A0 =A0 * For InnoDB Plugin, bit fields were causing problems with
> =A0 =A0 =A0 concurrency on SMP systems because of word-packing issues.
> =A0 =A0 =A0 (Bug#52360: http://bugs.mysql.com/bug.php?id=3D52360)
>
> =A0 =A0 * The optimizer could attempt to evaluate the WHERE clause
> =A0 =A0 =A0 before any rows had been read, resulting in a server crash.
> =A0 =A0 =A0 (Bug#52177: http://bugs.mysql.com/bug.php?id=3D52177)
>
> =A0 =A0 * For LDML-defined collations, some data structures were not
> =A0 =A0 =A0 initialized properly to enable UPPER() and LOWER() to work
> =A0 =A0 =A0 correctly. (Bug#51976: http://bugs.mysql.com/bug.php?id=3D519=
76)
>
> =A0 =A0 * On Windows, LOAD_FILE() could cause a crash for some
> =A0 =A0 =A0 pathnames. (Bug#51893: http://bugs.mysql.com/bug.php?id=3D518=
93)
>
> =A0 =A0 * Invalid memory reads occurred for HANDLER ... READ NEXT after
> =A0 =A0 =A0 a failed HANDLER ... READ FIRST.
> =A0 =A0 =A0 (Bug#51877: http://bugs.mysql.com/bug.php?id=3D51877)
>
> =A0 =A0 * After TRUNCATE TABLE of a MyISAM table, subsequent queries
> =A0 =A0 =A0 could crash the server if myisam_use_mmap was enabled.
> =A0 =A0 =A0 (Bug#51868: http://bugs.mysql.com/bug.php?id=3D51868)
>
> =A0 =A0 * If myisam_sort_buffer_size was set to a small value, table
> =A0 =A0 =A0 repair for MyISAM tables with FULLTEXT indexes could crash th=
e
> =A0 =A0 =A0 server. (Bug#51866: http://bugs.mysql.com/bug.php?id=3D51866)
>
> =A0 =A0 * In LOAD DATA INFILE, using a SET clause to set a column equal
> =A0 =A0 =A0 to itself caused a server crash.
> =A0 =A0 =A0 (Bug#51850: http://bugs.mysql.com/bug.php?id=3D51850)
>
> =A0 =A0 * A problem with equality propagation optimization for prepared
> =A0 =A0 =A0 statements and stored procedures caused a server crash upon
> =A0 =A0 =A0 re-execution of the prepared statement or stored procedure.
> =A0 =A0 =A0 (Bug#51650: http://bugs.mysql.com/bug.php?id=3D51650)
> =A0 =A0 =A0 See also Bug#8115: http://bugs.mysql.com/bug.php?id=3D8115,
> =A0 =A0 =A0 Bug#8849: http://bugs.mysql.com/bug.php?id=3D8849.
>
> =A0 =A0 * The optimizer performed an incorrect join type when COALESCE()
> =A0 =A0 =A0 appeared within an IN() operation.
> =A0 =A0 =A0 (Bug#51598: http://bugs.mysql.com/bug.php?id=3D51598)
>
> =A0 =A0 * The server crashed when the optimizer attempted to determine
> =A0 =A0 =A0 constant tables but a table storage engine did not support
> =A0 =A0 =A0 exact record count.
> =A0 =A0 =A0 (Bug#51494: http://bugs.mysql.com/bug.php?id=3D51494)
>
> =A0 =A0 * The server could crash populating the
> =A0 =A0 =A0 INFORMATION_SCHEMA.PROCESSLIST table due to lack of mutex
> =A0 =A0 =A0 protection.
> =A0 =A0 =A0 (Bug#51377: http://bugs.mysql.com/bug.php?id=3D51377)
>
> =A0 =A0 * Use of HANDLER statements with tables that had spatial indexes
> =A0 =A0 =A0 caused a server crash.
> =A0 =A0 =A0 (Bug#51357: http://bugs.mysql.com/bug.php?id=3D51357)
>
> =A0 =A0 * With an XA transaction active, SET autocommit =3D 1 could cause
> =A0 =A0 =A0 side effects such as memory corruption or a server crash.
> =A0 =A0 =A0 (Bug#51342: http://bugs.mysql.com/bug.php?id=3D51342)
>
> =A0 =A0 * Following a bulk insert into a MyISAM table, if MyISAM failed
> =A0 =A0 =A0 to build indexes using repair by sort, data file corruption
> =A0 =A0 =A0 could occur.
> =A0 =A0 =A0 (Bug#51307: http://bugs.mysql.com/bug.php?id=3D51307)
>
> =A0 =A0 * CHECKSUM TABLE could compute the checksum for BIT columns
> =A0 =A0 =A0 incorrectly.
> =A0 =A0 =A0 (Bug#51304: http://bugs.mysql.com/bug.php?id=3D51304)
>
> =A0 =A0 * A HAVING clause on a joined table in some cases failed to
> =A0 =A0 =A0 eliminate rows which should have been excluded from the resul=
t
> =A0 =A0 =A0 set. (Bug#51242: http://bugs.mysql.com/bug.php?id=3D51242)
>
> =A0 =A0 * The type inference used for view columns caused some columns
> =A0 =A0 =A0 in views to be handled as the wrong type, as compared to the
> =A0 =A0 =A0 same columns in base tables. DATE columns in base tables were
> =A0 =A0 =A0 treated as TIME columns in views, and base table TIME columns
> =A0 =A0 =A0 as view DATETIME columns.
> =A0 =A0 =A0 (Bug#50918: http://bugs.mysql.com/bug.php?id=3D50918)
>
> =A0 =A0 * The YEAR values 2000 and 0000 could be treated as equal.
> =A0 =A0 =A0 (Bug#49910: http://bugs.mysql.com/bug.php?id=3D49910)
>
> =A0 =A0 * Performing a single in-place ALTER TABLE containing ADD INDEX
> =A0 =A0 =A0 and DROP INDEX options that used the same index name could
> =A0 =A0 =A0 result in a corrupt table definition file. Now such ALTER
> =A0 =A0 =A0 TABLE statements are no longer performed in place.
> =A0 =A0 =A0 (Bug#49838: http://bugs.mysql.com/bug.php?id=3D49838)
>
> =A0 =A0 * mysql_upgrade did not detect when CSV log tables incorrectly
> =A0 =A0 =A0 contained columns that could be NULL. Now these columns are
> =A0 =A0 =A0 altered to be NOT NULL.
> =A0 =A0 =A0 (Bug#49823: http://bugs.mysql.com/bug.php?id=3D49823)
>
> =A0 =A0 * If a stored function contained a RETURN statement with an ENUM
> =A0 =A0 =A0 value in the ucs2 character set, SHOW CREATE FUNCTION and
> =A0 =A0 =A0 SELECT DTD_IDENTIFIER FROM INFORMATION_SCHEMA.ROUTINES
> =A0 =A0 =A0 returned incorrect values.
> =A0 =A0 =A0 (Bug#48766: http://bugs.mysql.com/bug.php?id=3D48766)
>
> =A0 =A0 * The server crashed when it could not determine the best
> =A0 =A0 =A0 execution plan for queries involving outer joins with
> =A0 =A0 =A0 nondeterministic ON clauses such as the ones containing the
> =A0 =A0 =A0 RAND() function, a user-defined function, or a NOT
> =A0 =A0 =A0 DETERMINISTIC stored function.
> =A0 =A0 =A0 (Bug#48483: http://bugs.mysql.com/bug.php?id=3D48483)
>
> =A0 =A0 * A query that read from a derived table (of the form SELECT ...
> =A0 =A0 =A0 FROM (SELECT ...)) produced incorrect results when the
> =A0 =A0 =A0 following conditions were present:
>
> =A0 =A0 =A0 =A0 =A0+ The table subquery contained a derived query ((SELEC=
T ...
> =A0 =A0 =A0 =A0 =A0 =A0) AS column).
>
> =A0 =A0 =A0 =A0 =A0+ The derived query could potentially produce zero row=
s or
> =A0 =A0 =A0 =A0 =A0 =A0a single NULL (that is, no rows matched, or the qu=
ery
> =A0 =A0 =A0 =A0 =A0 =A0used an aggregate function such as SUM() running o=
ver
> =A0 =A0 =A0 =A0 =A0 =A0zero rows).
>
> =A0 =A0 =A0 =A0 =A0+ The table subquery joined at least two tables.
>
> =A0 =A0 =A0 =A0 =A0+ The join condition involved an index.
> =A0 =A0 =A0 (Bug#47904: http://bugs.mysql.com/bug.php?id=3D47904)
>
> =A0 =A0 * The optimization to read MIN() or MAX() values from an index
> =A0 =A0 =A0 did not properly handle comparisons with NULL values. This
> =A0 =A0 =A0 could produce incorrect results for MIN() or MAX()when the
> =A0 =A0 =A0 WHERE clause tested a NOT NULL column for NULL.
> =A0 =A0 =A0 (Bug#47762: http://bugs.mysql.com/bug.php?id=3D47762)
>
> =A0 =A0 * Killing a query during the optimization phase of a subquery
> =A0 =A0 =A0 could cause a server crash.
> =A0 =A0 =A0 (Bug#47761: http://bugs.mysql.com/bug.php?id=3D47761)
>
> =A0 =A0 * The query shown by EXPLAIN EXTENDED plus SHOW WARNINGS could
> =A0 =A0 =A0 produce results different from the original query.
> =A0 =A0 =A0 (Bug#47669: http://bugs.mysql.com/bug.php?id=3D47669)
>
> =A0 =A0 * Renaming a column of an InnoDB table caused the server to go
> =A0 =A0 =A0 out of sync with the InnoDB data dictionary.
> =A0 =A0 =A0 (Bug#47621: http://bugs.mysql.com/bug.php?id=3D47621)
>
> =A0 =A0 * MyISAM could write uninitialized data to new index pages. Now
> =A0 =A0 =A0 zeros are written to unused bytes in the pages.
> =A0 =A0 =A0 (Bug#47598: http://bugs.mysql.com/bug.php?id=3D47598)
>
> =A0 =A0 * Setting myisam_repair_threads larger than 1 could result in
> =A0 =A0 =A0 the cardinality for all indexes of a MyISAM table being set t=
o
> =A0 =A0 =A0 1 after parallel index repair.
> =A0 =A0 =A0 (Bug#47444: http://bugs.mysql.com/bug.php?id=3D47444)
>
> =A0 =A0 * In debug builds, if the listed columns in the view definition
> =A0 =A0 =A0 of the table used in an INSERT ... SELECT statement
> =A0 =A0 =A0 mismatched, an assertion was raised in the query cache
> =A0 =A0 =A0 invalidation code following the failing statement.
> =A0 =A0 =A0 (Bug#46615: http://bugs.mysql.com/bug.php?id=3D46615)
>
> =A0 =A0 * For a query that selected from a view and used an alias for
> =A0 =A0 =A0 the view, the metadata used the alias name rather than the
> =A0 =A0 =A0 view name in the MYSQL_FIELD.table member.
> =A0 =A0 =A0 (Bug#41788: http://bugs.mysql.com/bug.php?id=3D41788)
>
> =A0 =A0 * mysql_upgrade did not create temporary files properly.
> =A0 =A0 =A0 (Bug#41057: http://bugs.mysql.com/bug.php?id=3D41057)
>
> =A0 =A0 * It was possible for DROP TABLE of one MyISAM table to remove
> =A0 =A0 =A0 the data and index files of a different MyISAM table.
> =A0 =A0 =A0 (Bug#40980: http://bugs.mysql.com/bug.php?id=3D40980)
>
> =A0 =A0 * If the arguments to a CONCAT() call included a local routine
> =A0 =A0 =A0 variable, selecting the return value into a user variable
> =A0 =A0 =A0 could produce an incorrect result.
> =A0 =A0 =A0 (Bug#40625: http://bugs.mysql.com/bug.php?id=3D40625)
>
> =A0 =A0 * SHOW CREATE VIEW returned invalid SQL if the definition
> =A0 =A0 =A0 contained a SELECT 'string' statement where the string was
> =A0 =A0 =A0 longer than the maximum length of a column name, due to the
> =A0 =A0 =A0 fact that this text was also used as an alias (in the AS
> =A0 =A0 =A0 clause).
> =A0 =A0 =A0 Because not all names retrieved from arbitrary SELECT
> =A0 =A0 =A0 statements can be used as view column names due to length and
> =A0 =A0 =A0 format restrictions, the server now checks the conformity of
> =A0 =A0 =A0 automatically generated column names and rewrites according t=
o
> =A0 =A0 =A0 a predefined format any names that are not acceptable as view
> =A0 =A0 =A0 column names before storing the final view definition on disk=
..
> =A0 =A0 =A0 In such cases, the name is now rewritten as Name_exp_pos,
> =A0 =A0 =A0 where pos is the position of the column. To avoid this
> =A0 =A0 =A0 conversion scheme, define explicit, valid names for view
> =A0 =A0 =A0 columns using the column_list clause of the CREATE VIEW
> =A0 =A0 =A0 statement.
> =A0 =A0 =A0 As part of this fix, aliases are now generated only for
> =A0 =A0 =A0 top-level statements.
> =A0 =A0 =A0 (Bug#40277: http://bugs.mysql.com/bug.php?id=3D40277)
>
> =A0 =A0 * While looking for the shortest index for a covering index
> =A0 =A0 =A0 scan, the optimizer ignored that a clustered primary key read
> =A0 =A0 =A0 the entire table.
> =A0 =A0 =A0 (Bug#39653: http://bugs.mysql.com/bug.php?id=3D39653)
>
> =A0 =A0 * mysqlbinlog had a memory leak in its option-processing code.
> =A0 =A0 =A0 (Bug#38468: http://bugs.mysql.com/bug.php?id=3D38468)
>
> =A0 =A0 * The test for readline during configuration failed when trying
> =A0 =A0 =A0 to build MySQL in a directory other than the source tree root=
..
> =A0 =A0 =A0 (Bug#35250: http://bugs.mysql.com/bug.php?id=3D35250)
>
> Thanks,
> MySQL RE Team
>
> Hery Ramilison, Karen Langford, MySQL Release Engineers
> Database Group, Oracle.


For the record I think it is really bad form that ~10 of ~50 bugs
noted are non-public. This is really annoying. Trying to make
judgments about risks of upgrading vs not upgrading with non-public
bugs is very difficult.

--=20
Rob Wultsch
wultsch@gmail.com

--
MySQL General Mailing List
For list archives: http://lists.mysql.com/mysql
To unsubscribe: http://lists.mysql.com/mysql?unsub=3Dgcdmg-mysql-2@m.gmane.o rg