MySQL 5.6.16/5.5.36 发布

2014年02月01日 10:15 次阅读 稿源:OSChina 条评论

MySQL各产品线更新。5.6.16/5.5.36 2014-01-31之前版本是2013-09-20的5.6.15/5.5.35,主要是Bug修正,cmake支持了-DTMPDIR,增强了ALTER_TABLE.5.1系列还是5.1.73.

完全改进:

Changes in MySQL 5.6.16 (2014-01-31)

A known limitation of this release:

Note

Building MySQL from source on Windows using Visual Studio 2008          fails with an identifier not found error. Later versions of Visual Studio are unaffected. The          workaround is to set the CMake build          option, INNODB_PAGE_ATOMIC_REF_COUNT, toOFF. This option isONby default.

Functionality Added or Changed

  • Previously, ALTER TABLE in MySQL        5.6 could alter a table such that the result had temporal        columns in both 5.5 and 5.6 format. Now ALTER TABLE upgrades old temporal        columns to 5.6 format forADD COLUMN,CHANGE COLUMN,MODIFY        COLUMN,ADD INDEX, andFORCEoperations. This conversion cannot be        done using theINPLACEalgorithm, so        specifyingALGORITHM=INPLACEin these cases        results in an error.       (Bug #17246318)

  • CMake now supports a -DTMPDIR=dir_name option to specify the default tmpdir value. If unspecified,        the value defaults toP_tmpdirin<stdio.h>. Thanks to Honza Horak for        the patch.       (Bug #68338, Bug #16316074)

Bugs Fixed

  • InnoDB; Replication: Using the InnoDB memcachedplugin (see InnoDBIntegration with memcached) with innodb_api_enable_binlog set to        1 caused the server to leak memory.       (Bug #70757, Bug #17675622)

  • InnoDB: A boolean mode full-text search query would result in a memory        access violation during parsing.       (Bug #17978763)

  • InnoDB: When new indexes are added by an ALTER        TABLE operation, instead of only saving table-level        statistics and statistics for the new indexes,InnoDBwould save statistics for the entire        table, including the table's other indexes. This behavior slowed ALTER TABLE performance.       (Bug #17848838, Bug #16511145)

  • InnoDB: Due to a parser error, full-text search queries that include a        sub-expression could return the wrong result.       (Bug #17840768)

  • InnoDB: The innochecksum tool did not use a        Windows-specific API to retrieve file size information, which        resulted in an incorrect error message (Error:        ibdata1 cannot be found) when the MySQL 5.6 innochecksum 2GB file size limit was        exceeded. innochecksum now provides support        for files larger than 2GB in both MySQL 5.6 and MySQL 5.7.       (Bug #17810862, Bug #70936)

  • InnoDB: Due to a regression introduced by the fix for Bug#17371537,        memory was not allocated for the default memcached engine when        using the default memcached engine as the backstore for data        instead ofInnoDB.       (Bug #17800829)

  • InnoDB: InnoDBwould report an incorrect operating        system error code after failing to initialize.       (Bug #17788055, Bug #70867)

  • InnoDB: Manipulating a table after discarding its tablespace using ALTER TABLE ...        DISCARD TABLESPACE could result in a serious error.       (Bug #17700280)

  • InnoDB: Persistent optimizer statistics would cause stalls due to latch        contention.       (Bug #17699331, Bug #70768)

  • InnoDB:MATCH() ... AGAINST queries that        use a long string as an argument forAGAINST()could result in an error when run        on anInnoDBtable with a full-text search        index.       (Bug #17640261)

  • InnoDB: AnInnoDBfull-text search failure would        occur due to an “unended” token. The string and        string length should be passed for string comparison.       (Bug #17659310)

  • InnoDB: In debug builds, a merge insert buffer during a page read would        cause a memory access violation.       (Bug #17561188)

  • InnoDB: Truncating a memcached InnoDBtable while memcached is performing DML operations would        result in a serious error.       (Bug #17468031)

  • InnoDB: Insync0rw.ic,rw_lock_x_lock_func_nowaitwould needlessly        callos_thread_get_curr_id.       (Bug #17509710, Bug #70417)

  • InnoDB: Attempting to rename a table to a missing database would result        in a serious error.       (Bug #17447500)

  • InnoDB: If a tablespace data file path is updated in a.islfile and then a crash recovery is        performed, the updated tablespace data file path is read from        the.islfile but theSYS_DATAFILEStable would not be not updated.        TheSYS_DATAFILEStable is now updated with        the new data file path after crash recovery.       (Bug #17448389)

  • InnoDB: If the first page (page 0) of file-per-table tablespace data        file was corrupt, recovery would be halted even though the        doublewrite buffer contained a clean copy of the page.       (Bug #17335427, Bug #70087)

  • InnoDB: TheInnoDBmemcached Readme file (README-innodb_memcached)        incorrectly stated that libevent 1.6.0 is linked statically into        daemon memcached. The bundled version of        libevent is 1.4.12, not 1.6.0.       (Bug #17324419, Bug #70034)

  • InnoDB: Attempting to reset a replication slave while innodb_force_recovery is        greater than0would return a cryptic error        message: ERROR(1030) HY000: Got error -1 from storage        engine. The error message has been changed to: ERROR HY000: Operation not allowed when        innodb_force_recovery > 0. Replication options such        as --relay-log-info-repository=TABLE and --master-info-repository=TABLE store information in tables inInnoDB. When innodb_force_recovery is        greater than 0, replication tables cannot be updated which may        cause replication administration commands to fail.       (Bug #17287443, Bug #69907)

  • InnoDB: The ALTER TABLE INPLACEalgorithm would fail to decrease the        auto-increment value.       (Bug #17250787, Bug #69882)

  • InnoDB: Comments inbtr0cur.ccincorrectly stated        thatbtr_cur_pessimistic_update()andbtr_cur_optimistic_update()would accept a        NULL value.       (Bug #17231743, Bug #69847)

  • InnoDB: dict_table_schema_checkwould calldtype_sql_nameneedlessly.       (Bug #17193801, Bug #69802)

  • InnoDB: The functionos_file_get_statuswould not        work with raw devices.       (Bug #17023438, Bug #69424)

  • InnoDB: During crash recovery, an incorrect transaction active time        would result in rolling back an uncommitted transaction.       (Bug #16936961, Bug #69438)

  • InnoDB: Heap block debugging information (file_name,lineno), used for logging diagnostics, would        appear in release builds. This information should only appear in        debug builds.       (Bug #16924719, Bug #69422)

  • InnoDB: Renaming a column while also adding or dropping columns in the        same ALTER TABLE operation would        cause an error.       (Bug #16864981)

  • InnoDB: An online ALTER TABLE operation        would consume more memory than expected. During an onlineALTER TABLEoperation, an online log buffer        containing a head and tail buffer is created for each index that        is created or rebuilt. The tail buffer is the writer context and        is only required for concurrent write operations on an index        while theALTER TABLEoperation is in        progress. The head buffer is the reader context and is only        required during the log apply phase. To reduce memory        consumption, the tail buffer is now allocated when the first DML        statement is run on the index, and the head buffer is only        allocated in the log apply phase and freed afterwards.       (Bug #16868967, Bug #69325, Bug #17911720)

  • InnoDB: On Windows, the full-text search (FTS) object ID was not in the        expected hexadecimal format.       (Bug #16559254)

    References: See also Bug #16559119.

  • InnoDB: Fetching and releasing pages from the buffer pool and tracking        the page state are expensive and complex operations. Prior to        the bug fix, these operations were performed using a page mutex.        Using a page mutex to track several things is expensive and does        not scale well. The bug fix separates fetch and release tracking        (in-use state) of a page from page I/O state tracking. Fetch and        release is now tracked using atomics where available.

    For portability, a newCMakebuild option, INNODB_PAGE_ATOMIC_REF_COUNT (defaultON), can be used to disable atomic        page reference counting on platforms where atomics support is        not available. When atomic page reference counting is enabled        (default), “[Note] InnoDB: Using atomics to ref        count buffer pool pages” is printed to the        error log at server startup. If atomic page reference counting        is disabled, “[Note] InnoDB: Using mutexes to ref        count buffer pool pages” is printed instead.       (Bug #16249481, Bug #68079)

  • InnoDB: Table renaming errors would appear in theLATEST        FOREIGN KEY ERRORsection of theSHOW ENGINE        INNODB STATUSoutput.       (Bug #12762390, Bug #61746)

  • InnoDB: UNIV_SYNC_DEBUG, which was disabled inuniv.iwith the fix for Bug#16720368, is now        enabled.       (Bug #69617, Bug #17033591)

  • Partitioning: Queries using theindex_mergeoptimization        (see Index Merge Optimization) could return        invalid results when run against tables that were partitioned byHASH.       (Bug #17588348, Bug #70588)

  • Partitioning: When no partition had returned a row since the last HA_ERR_KEY_NOT_FOUND error, the use of        uninitialized memory in the priority queue used for returning        rows in sorted order could lead to a crash of the server.       (Bug #17401628)

  • Replication: When the binary log I/O cache grew to exactly 32768 bytes and        the current transaction was preceded by a transaction whose size        was greater than 32768 bytes, events could be corrupted when        written into the binary log.       (Bug #17842137)

  • Replication: Creating and dropping large numbers of temporary tables could        lead to increased memory consumption.       (Bug #17806014)

  • Replication:mysqlbinlog--verbose failed when it        encountered a corrupt row event in the binary log. Such a row        event could also cause the slave to fail.       (Bug #17632978)

    References: See also Bug #16960133.

  • Replication: When log_warnings is greater        than 1, the master prints binary log dump thread        information—containing the slave server ID, binary log        file name, and binary log position—inmysqld.1.err. A slave server ID greater        than 2 billion was printed with a negative value in such cases.       (Bug #17641586, Bug #70685)

  • Replication:mysqlbinlog did not properly decode DECIMAL values in a row-based        binary log. This could cause invalid values to be printed out        forDECIMALcolumns.       (Bug #17544169)

    References: See also Bug #14309019.

  • Replication: Seconds_Behind_Masterin the output of SHOW SLAVE STATUS could under        some conditions be reported as 0 when it should have had a value        greater than zero.       (Bug #17233214)

    References: See also Bug #16579028.

  • Replication: The semisynchronous replication plugin was called twice for a        DDL statement, incrementing Rpl_semi_sync_master_yes_tx by        2 instead of 1 each time such a statement was executed.       (Bug #70410, Bug #17509011)

  • Compilation errors occurred on Solaris 10; resolved by includingmy_config.hbefore system header files.       (Bug #18046811)

  • FORCE INDEX [FOR ORDER BY]        (index_name)did not work        for joins.

    The fix for this bug also also changes the warning created for EXPLAIN. Instead of printing only{IGNORE|USE|FORCE} INDEXit now also printsFOR {GROUP BY|ORDER BY|JOIN}if that was        specified in the query.       (Bug #17889511)

  • With the compressed client/server protocol enabled, Performance        Schema statement instrumentation could raise an assertion.       (Bug #17794846)

  • In some cases, UNIX_TIMESTAMP() could returnNULLwhen it should return 0.       (Bug #17728371)

  • An assertion could be raised if afilesortfailed to resize its main buffer when record properties changed.       (Bug #17757914)

  • The cache used for the Index Merge access method was freed only        after successful retrieval of all rows. Interruption or failure        of the operation led to a file descriptor leak.       (Bug #17708621)

  • Using the mysqldump--set-gtid-purged option with        no value caused mysqldump to crash.       (Bug #17650245)

  • A race condition between Performance Schema statement event        threads led to a server exit.       (Bug #17637970)

  • In a view definition requireing resolution of aggregrate        expressions within a subquery to an outer query, selecting from        the view could cause a server exit.       (Bug #17547804)

    References: This bug is a regression of Bug #16436383.

  • An addressing error in accessing the join buffer could produce        invalid results or a server exit.       (Bug #17513341)

  • mysql_config incorrectly included some flags        to generate compiler warning output.       (Bug #17400967)

  • With semi-join optimization enabled, queries with nested        subqueries could cause a server exit due to incorrect resolution        of references to columns in the MIDdle query block.       (Bug #17398972)

  • In some cases, the optimizer wrote fixed-length temporaryMyISAMtables to disk rather than        variable-length temporary tables.       (Bug #17231940)

  • Enabling thevalidate_passwordplugin could        result in incorrect password hashes being stored in themysql.usertable.       (Bug #17065383)

  • For accounts authenticated using thesha256_passwordplugin, setting the password        after the password had been expired did not clear the        password-expired flag.       (Bug #16872181)

  • On Mac OS X 10.7, a race condition involvingvio_shutdown()and the select-based        implementation ofvio_io_wait()could cause a        server exit.       (Bug #16354789, Bug #17733393)

  • Host names in example URLs used within the source code were        replaced by names in the example.com domain, the domain intended        by IANA for this purpose.       (Bug #15890092)

  • Forutf8andutf8mb4strings, handler functions unnecessarily called a Unicode        conversion function.       (Bug #14057034)

  • Several-Wwarning flags were turned off for        compilation in maintainer mode if MySQL was configured with-DWITH_INNODB_MEMCACHED=1.       (Bug #13898319)

  • Calling the ExtractValue() function with an invalid XPath expression could in some cases        lead to a failure of the server.       (Bug #12428404, Bug #61065)

  • Use of a nonmulti-byte algorithm for skipping leading spaces in        multi-byte strings could cause a server exit.       (Bug #12368495)

  • WithONLY_FULL_GROUP_BYSQL mode enabled, a        query that usesGROUP BYon a column derived        from a subquery in theFROMclause failed        with acolumn isn't in GROUP BYerror, if the        query was in a view.       (Bug #11923239)

  • For theutf8_bincollation,ORDER BY        LOWER(col_name)could        produce incorrect ordering.       (Bug #69005, Bug #16691598)

  • Several issues identified by the Coverity static analysis tool        were fixed. Thanks to Honza Horak for the patch.       (Bug #70830, Bug #17760511)

  • On Windows, the --local-service server option did not work, and was not displayed in the --help message.       (Bug #69637, Bug #17049656)

  • It was not possible to query a view with anORDER        BYclause that referenced an alias in theSELECTclause of the view definition, unless        all columns in the view were named in the select list.

    To handle this problem, the server now writes a view differently        into the.frmfile that stores the view        definition. If you experience view-evaluation errors such as        just described, drop and recreate the view so that the.frmfile contains the updated view        representation.       (Bug #69678, Bug #17077305)

  • The prototype of the Performance Schema instrumentation APImysql_cond_timedwait()call was fixed to be        drop-in compatible withpthread_cond_timedwait(). This fix affects        only implementers of third-party plugins.       (Bug #70628, Bug #17702677)

  • Themake_atomic_cas_body64implementation on        IA32 with gcc but without gcc builtins could be miscompiled due to an        incorrect constraint. The patch also causes MySQL to use builtin        atomics when compiled using Clang.       (Bug #63451, Bug #17242996)

  • Complex updates of Performance Schema tables involving joins or        subqueries failed to update every row.       (Bug #70025, Bug #17309657)

  • For the path specified with the --basedir option, mysql_plugin attempted to unlink the path        rather than free the memory in which the path was stored.       (Bug #69752, Bug #17168602)

  • COUNT(DISTINCT) sometimes produced an incorrect result when the        last read row contained aNULLvalue.       (Bug #68749, Bug #16539979, Bug #71028, Bug #17867117)

  • sql_resolver.ccreferred to partitioning        code that should have been protected by an#ifdef, even when MySQL was configured with-DWITH_PARTITION_STORAGE_ENGINE=OFF.       (Bug #71010, Bug #17876794)

  • In incorrect result could be returned for a query with an IF() predicate in theWHEREclause combined withOUTER        JOINin a subquery that is transformed to a semi-join.        (A workaround is to disable semi-join usingSET        optimizer_switch='semijoin=off';)       (Bug #70608, Bug #17600176)

  • A full-text search combined with derived tables (subqueries in        theFROMclause) caused a server exit.

    Now if a full-text operation depends on a derived table, the        server produces an error indicating that a full-text search        cannot be done on a materialized table.       (Bug #68751, Bug #16539903)

  • Some scripts displayed out-of-date information regarding where        to report bugs.       (Bug #68742, Bug #16530527)

  • Some files in the Performance Schema file_instances table were not being        removed because the file-removal operation was not instrumented.       (Bug #69782, Bug #17209750)

  • mysqldump --single-transaction acquired        metadata locks for each dumped table but did not release them        until the dump operation finished. Consequently, other DDL        operations on a dumped table blocked even after the table itself        had been dumped. mysqldump now attempts to        release metadata locks earlier.       (Bug #71017, Bug #17862905)

  • Updating aFEDERATEDtable withUPDATE... JOINcaused a server exit when the        local table contained a single row and that row could be joined        to a row in theFEDERATEDtable.       (Bug #68354, Bug #16324629)

  • mysql_install_dbreferred to the obsolete mysqlbug script for reporting problems. It        now refers to http://bugs.mysql.com/ instead.       (Bug #29716, Bug #11746921)

http://dev.mysql.com/doc/relnotes/mysql/5.5/en/news-5-5-36.html

下载:ftp://mirror.switch.ch/mirror/mysql/Downloads/MySQL-5.6/mysql-5.6.16.tar.gz

ftp://mirror.switch.ch/mirror/mysql/Downloads/MySQL-5.5/mysql-5.5.36.tar.gz

对文章打分

MySQL 5.6.16/5.5.36 发布

1 (20%)
已有 条意见

    最新资讯

    加载中...

    编辑精选

    加载中...

    热门评论

      Top 10

      招聘

      created by ceallan