オリジナル版:http://dev.mysql.com/doc/refman/5.1/en/news-5-1-36.html
最も普及しているオープンソースデータベース管理システムの新バージョンであるMySQL Community Server 5.1.36がリリースされました。MySQL 5.1.36は、プロダクションシステムでの使用をお勧めします。
MySQL 5.1の新機能の概要については、以下を参照してください。
http://dev.mysql.com/doc/refman/5.1/en/mysql-nutshell.html
新たなサーバにMySQL 5.1.36をインストール、または以前のMySQLリリースからMySQL 5.1.36にアップグレードする際の情報については、以下を参照してください。
http://dev.mysql.com/doc/refman/5.1/en/installing.html
MySQL 5.1.36は、http://dev.mysql.com/downloads/から、ソースコード及び多くのプラットフォームのためのバイナリで現在利用可能です。
すべてのミラーサイトが現在、最新であるとは限らないことに注意してください。
あるミラーサイトで本バージョンを見つけることができない場合は、再度確認を行うか、あるいは別のダウンロード・サイトを選択してください。
バグレポート、バグ修正、パッチ等の情報をお待ちしておりますので、以下のページをご利用ください。
http://forge.mysql.com/wiki/Contributing
MySQL 5.1に関するオープンな問題の情報については、以下のエラッタリストを参照してください。
http://dev.mysql.com/doc/refman/5.1/en/open-bugs.html
以下のセクションはMySQL5.1の以前のリリース以来のMySQLソースコードにおけるバージョン間の変更を記載しています。
http://dev.mysql.com/doc/refman/5.1/en/news-5-1-36.html
以下は、追加または変更された機能です。
=======================================================================
Functionality added or changed:
* Important Change: Replication: Previously, incident log
events were represented as comments in the output from
mysqlbinlog, making them effectively silent when playing
back the binlog.
(An incident log event represents an incident that could
cause the contents of the database to change without that
event being recorded in the binary log.)
This meant that, if the SQL were applied to a server, it
could potentially lead to the master and the slave having
different data. To make it possible to handle incident
log events without breaking applications that expect the
previous behavior, the nonsense statement RELOAD DATABASE
is added to the SQL output for that incident log event,
which causes an error.
To use this functionality currently requires hand editing
of the dump file and handling of each case on an
individual basis by a database administrator before
applying the output to a server.
(Bug#44442:http://bugs.mysql.com/44442)
* The time zone tables for Windows available at
timezones.html have been updated.
(Bug#39923:http://bugs.mysql.com/39923)
* The mysqltest program now has a move_file from_file
to_file command for renaming files. This should be used
in test cases rather than invoking an external command
that might be platform specific.
(Bug#39542:http://bugs.mysql.com/39542)
Bugs fixed:
* Incompatible Change: The server can load plugins under
the control of startup options. For example, many storage
engines can be built in pluggable form and loaded when
the server starts. In the following descriptions,
plugin_name stands for a plugin name such as innodb.
Previously, plugin options were handled like other
boolean options (see Section 4.2.3.2, "Program Option
Modifiers"). That is, any of these options enabled the
plugin:
--plugin_name
--plugin_name=1
--enable-plugin_name
And these options disabled the plugin:
--plugin_name=0
--disable-plugin_name
--skip-plugin_name
However, use of a boolean option for plugin loading did
not provide control over what to do if the plugin failed
to start properly: Should the server exit, or start with
the plugin disabled? The actual behavior has been that
the server starts with the plugin disabled, which can be
problematic. For example, if InnoDB fails to start,
existing InnoDB tables become inaccessible, and attempts
to create new InnoDB tables result in tables that use the
default storage engine unless the NO_ENGINE_SUBSTITUTION
SQL mode has been enabled to cause an error to occur
instead.
Now, there is a change in the options used to control
plugin loading, such that they have a tristate format:
+ --plugin_name=OFF
Do not enable the plugin.
+ --plugin_name[=ON]
Enable the plugin. If plugin initialization fails,
start the server anyway, but with the plugin
disabled. Specifying the option as --plugin_name
without a value also enables the plugin.
+ --plugin_name=FORCE
Enable the plugin. If plugin initialization fails,
do not start the server. In other words, force the
server to run with the plugin or not at all.
The values OFF, ON, and FORCE are not case sensitive.
Suppose that CSV and InnoDB have been built as pluggable
storage engines and that you want the server to load them
at startup, subject to these conditions: The server is
allowed to run if CSV initialization fails, but must
require that InnoDB initialization succeed. To accomplish
that, use these lines in an option file:
[mysqld]
csv=ON
innodb=FORCE
This change is incompatible with the previous
implementation if you used options of the form
--plugin_name=0 or --plugin_name=1, which should be
changed to --plugin_name=OFF or --plugin_name=ON,
respectively.
--enable-plugin_name is still supported and is the same
as --plugin_name=ON. --disable-plugin_name and
--skip-plugin_name are still supported and are the same
as --plugin_name=OFF.
(Bug#19027:http://bugs.mysql.com/19027)
* Replication: When using row-based logging, the length of
an event for which the field metadata exceeded 255 bytes
in size was incorrectly calculated. This could lead to
corruption of the binary log, or cause the server to
hang. (Bug#42749:http://bugs.mysql.com/42749)
See alsoBug#44548:http://bugs.mysql.com/44548,
Bug#44672:http://bugs.mysql.com/44672,
Bug#44752:http://bugs.mysql.com/44752.
* Replication: The warning Statement is not safe to log in
statement format, issued in situations when it cannot be
determined that a statement or other database event can
be written reliably to the binary log using the
statement-based format, has been changed to Statement may
not be safe to log in statement format.
(Bug#42415:http://bugs.mysql.com/42415)
* Replication: When stopping and restarting the slave while
it was replicating temporary tables, the slave server
could crash or raise an assertion failure. This was due
to the fact that, although temporary tables were saved
between slave thread restarts, the reference to the
thread being used (table->in_use) was not being properly
updated when restarting, continuing to reference the old
thread instead of the new one. This issue affected
statement-based replication only.
(Bug#41725:http://bugs.mysql.com/41725)
* ALTER TABLE on a view crashed the server.
(Bug#44860:http://bugs.mysql.com/44860)
* UNCOMPRESSED_LENGTH() returned a garbage result when
passed a string shorter than 5 bytes. Now
UNCOMPRESSED_LENGTH() returns NULL and generates a
warning. (Bug#44796:http://bugs.mysql.com/44796)
* Several Valgrind warnings were silenced.
(Bug#44774:http://bugs.mysql.com/44774,
Bug#44792:http://bugs.mysql.com/44792)
* Selecting RAND(N) function where N is a column of a
constant table (table with a single row) failed with a
SIGFPE signal. (Bug#44768:http://bugs.mysql.com/44768)
* Conversion of a string to a different character set could
use the same buffer for input and output, leading to
incorrect results or warnings.
(Bug#44743:http://bugs.mysql.com/44743,
Bug#44766:http://bugs.mysql.com/44766)
* mysqld_safe could fail to find the logger program.
(Bug#44736:http://bugs.mysql.com/44736)
* A Valgrind warning related to transaction processing was
silenced. (Bug#44664:http://bugs.mysql.com/44664)
* innochecksum could incorrectly determine the input file
name from the arguments.
(Bug#44484:http://bugs.mysql.com/44484)
* Incorrect time was reported at the end of mysqldump
output. (Bug#44424:http://bugs.mysql.com/44424)
* Caching of GROUP BY expressions could lead to mismatches
between compile-time and runtime calculations and cause a
server crash. (Bug#44399:http://bugs.mysql.com/44399)
* Lettercase conversion in multibyte cp932 or sjis
character sequences could produce incorrect results.
(Bug#44352:http://bugs.mysql.com/44352)
* InnoDB was missing DB_ROLL_PTR information in Table
Monitor COLUMNS output.
(Bug#44320:http://bugs.mysql.com/44320)
* Assertion failure could occur for duplicate-key errors in
INSERT INTO ... SELECT statements.
(Bug#44306:http://bugs.mysql.com/44306)
* On 64-bit Windows systems, myisamchk did not handle
key_buffer_size values larger than 4GB.
(Bug#43940:http://bugs.mysql.com/43940)
* EXPLAIN EXTENDED could crash for UNION queries in which
the last SELECT was not parenthesized and included an
ORDER BY clause. (Bug#43612:http://bugs.mysql.com/43612)
* Multiple-table updates for InnoDB tables could produce
incorrect results.
(Bug#43580:http://bugs.mysql.com/43580)
* For DELETE statements with ORDER BY var, where var was a
global system variable with a NULL value, the server
could crash. (Bug#42778:http://bugs.mysql.com/42778)
* Builds linked against OpenSSL had a memory leak in
association with use of X509 certificates.
(Bug#42158:http://bugs.mysql.com/42158)
* There was a race condition when changing
innodb_commit_concurrency at runtime from zero to nonzero
or from nonzero to zero. Now this variable cannot be
changed at runtime from zero to nonzero or vice versa.
The value can still be changed from one nonzero value to
another. (Bug#42101:http://bugs.mysql.com/42101)
* SELECT ... INTO @var could produce values different from
SELECT ... without the INTO clause.
(Bug#42009:http://bugs.mysql.com/42009)
* mysql_zap did not work on Mac OS X.
(Bug#41883:http://bugs.mysql.com/41883)
* For views created with a column list clause, column
aliases were not substituted when selecting through the
view using a HAVING clause.
(Bug#40825:http://bugs.mysql.com/40825)
* A multiple-table DELETE involving a table self-join could
cause a server crash.
(Bug#39918:http://bugs.mysql.com/39918)
* Creating an InnoDB table with a comment containing a '#'
character caused foreign key constraints to be omitted.
(Bug#39793:http://bugs.mysql.com/39793)
* The mysql option --ignore-spaces was nonfunctional.
(Bug#39101:http://bugs.mysql.com/39101)
* If a query was such as to produce the error 1054 Unknown
column '...' in 'field list', using EXPLAIN EXTENDED with
the query could cause a server crash.
(Bug#37362:http://bugs.mysql.com/37362)
* If the MYSQL_HISTFILE environment variable was set to
/dev/null, the mysql client overwrote the /dev/null
device file as a normal file.
(Bug#34224:http://bugs.mysql.com/34224)
* mysqld_safe mishandled certain parameters if they
contained spaces.
(Bug#33685:http://bugs.mysql.com/33685)
* mysqladmin kill did not work for thread IDs larger than
32 bits. (Bug#32457:http://bugs.mysql.com/32457)
* Several client programs failed to interpret
--skip-password as "send no password."
(Bug#28479:http://bugs.mysql.com/28479)
* Output from mysql --html did not encode the <, >, or &
characters. (Bug#27884:http://bugs.mysql.com/27884)
* mysql_convert_table_format did not prevent converting
tables to MEMORY or BLACKHOLE tables, which could result
in data loss. (Bug#27149:http://bugs.mysql.com/27149)