[Commits] e5a4f316f5a: WIP merge 10.3 into 10.4
revision-id: e5a4f316f5af8e21e73bcdee6e2b1ad95ebb206d (mariadb-10.3.6-139-ge5a4f316f5a) parent(s): 539a165b7a470baad1f3fcda7dde1ed6a81b1c2e 1005376e588dd99846c86f33d86ffdec9de6c213 author: Marko Mäkelä committer: Oleksandr Byelkin timestamp: 2019-02-20 12:02:52 +0100 message: WIP merge 10.3 into 10.4 Unresolved conflicts: both modified: mysql-test/suite/galera_3nodes/r/galera_garbd.result both modified: mysql-test/suite/galera_3nodes/r/galera_var_dirty_reads2.result both modified: mysql-test/suite/galera_3nodes/t/galera_garbd.test both modified: scripts/mysql_install_db.sh both modified: sql/item.cc both modified: sql/sql_table.cc both modified: sql/sql_time.cc both modified: sql/sql_yacc.yy both modified: sql/sql_yacc_ora.yy both modified: sql/table.cc CMakeLists.txt | 12 +- client/mysqlbinlog.cc | 23 +- client/mysqltest.cc | 66 +- cmake/build_configurations/mysql_release.cmake | 1 - cmake/readline.cmake | 2 +- cmake/submodules.cmake | 12 +- config.h.cmake | 6 +- configure.cmake | 2 +- extra/mariabackup/backup_copy.cc | 13 + extra/mariabackup/xtrabackup.cc | 44 +- include/my_sys.h | 5 +- include/my_valgrind.h | 4 +- include/mysql.h | 2 +- include/mysql.h.pp | 2 +- libmariadb | 2 +- mysql-test/include/check-testcase.test | 1 - mysql-test/include/mtr_check.sql | 1 - mysql-test/main/alter_table.result | 49 + mysql-test/main/alter_table.test | 17 + mysql-test/main/alter_table_errors.result | 6 + mysql-test/main/alter_table_errors.test | 10 + mysql-test/main/check.result | 7 + mysql-test/main/check.test | 9 + mysql-test/main/check_constraint.result | 2 +- mysql-test/main/check_constraint.test | 1 - mysql-test/main/check_constraint_innodb.result | 9 + mysql-test/main/check_constraint_innodb.test | 14 + mysql-test/main/disabled.def | 1 + mysql-test/main/error_simulation.result | 5 +- mysql-test/main/error_simulation.test | 7 +- mysql-test/main/func_misc.result | 8 + mysql-test/main/func_misc.test | 8 + mysql-test/main/gis.test | 1 - mysql-test/main/gis2.result | 2 +- mysql-test/main/mysql.result | 26 + mysql-test/main/mysql.test | 22 + mysql-test/main/mysqlbinlog_row_minimal.result | 122 +- mysql-test/main/mysqlbinlog_row_minimal.test | 41 + mysql-test/main/row-checksum-old.result | 16 + mysql-test/main/row-checksum.result | 16 + mysql-test/main/row-checksum.test | 17 + mysql-test/main/subselect2.result | 22 + mysql-test/main/subselect2.test | 20 + mysql-test/main/subselect_mat.result | 16 + mysql-test/main/subselect_mat.test | 13 + mysql-test/main/subselect_sj2_mat.result | 4 +- mysql-test/suite/archive/partition_archive.result | 4 +- mysql-test/suite/archive/partition_archive.test | 3 +- .../suite/binlog/r/binlog_base64_flag.result | 19 + .../binlog/r/binlog_mysqlbinlog_row_frag.result | 24 + mysql-test/suite/binlog/t/binlog_base64_flag.test | 22 + .../binlog/t/binlog_mysqlbinlog_row_frag.test | 46 + .../encryption/r/innodb-encryption-alter.result | 4 +- .../encryption/t/innodb-encryption-alter.test | 2 - .../suite/encryption/t/innodb-spatial-index.test | 2 - mysql-test/suite/galera/r/galera_defaults.result | 1 + mysql-test/suite/galera_3nodes/galera_2x3nodes.cnf | 1 + mysql-test/suite/galera_3nodes/galera_3nodes.cnf | 1 + .../galera_3nodes/include/have_mariabackup.inc | 4 - .../suite/galera_3nodes/r/galera_garbd.result | 8 + .../galera_3nodes/r/galera_var_dirty_reads2.result | 8 + mysql-test/suite/galera_3nodes/suite.pm | 9 +- mysql-test/suite/galera_3nodes/t/galera_garbd.test | 26 + .../galera_3nodes/t/galera_ipv6_mariabackup.test | 2 +- .../galera_3nodes/t/galera_var_dirty_reads2.test | 14 + .../suite/gcol/inc/gcol_column_def_options.inc | 1 - mysql-test/suite/gcol/inc/gcol_keys.inc | 1 - mysql-test/suite/gcol/r/gcol_keys_innodb.result | 2 +- mysql-test/suite/gcol/r/innodb_virtual_fk.result | 4 +- mysql-test/suite/gcol/t/innodb_virtual_fk.test | 2 - mysql-test/suite/innodb/r/add_constraint.result | 2 +- .../suite/innodb/r/alter_foreign_crash.result | 2 +- .../suite/innodb/r/alter_varchar_change.result | 9 + mysql-test/suite/innodb/r/foreign_key.result | 57 +- .../suite/innodb/r/innodb-fk-warnings.result | 24 +- mysql-test/suite/innodb/r/innodb-fk.result | 6 +- .../suite/innodb/r/innodb-index-online.result | 2 +- mysql-test/suite/innodb/r/innodb-index.result | 10 +- .../suite/innodb/r/innodb_force_recovery.result | 8 +- .../suite/innodb/r/instant_varchar_enlarge.result | 9 - .../suite/innodb/r/undo_truncate_recover.result | 1 + mysql-test/suite/innodb/t/add_constraint.test | 1 - .../suite/innodb/t/alter_varchar_change.test | 7 + mysql-test/suite/innodb/t/foreign_key.test | 52 +- mysql-test/suite/innodb/t/innodb-fk-warnings.test | 18 - mysql-test/suite/innodb/t/innodb-fk.test | 2 - mysql-test/suite/innodb/t/innodb-index-online.test | 1 - mysql-test/suite/innodb/t/innodb-index.test | 5 - .../innodb/t/innodb-page_compression_tables.test | 4 - .../suite/innodb/t/innodb_force_recovery.test | 4 - .../suite/innodb/t/instant_varchar_enlarge.test | 8 - .../suite/innodb/t/undo_truncate_recover.test | 6 +- .../suite/innodb_gis/r/alter_spatial_index.result | 2 +- mysql-test/suite/innodb_gis/r/point_basic.result | 14 +- mysql-test/suite/innodb_gis/t/point_basic.test | 6 - .../suite/mariabackup/incremental_rocksdb.opt | 1 + .../suite/mariabackup/incremental_rocksdb.result | 19 + .../suite/mariabackup/incremental_rocksdb.test | 38 + .../perfschema/r/dml_setup_instruments.result | 4 +- .../suite/perfschema/t/dml_setup_instruments.test | 5 +- mysql-test/suite/plugins/t/audit_null.test | 2 +- mysql-test/suite/rpl/r/rpl_set_statement.test | 0 mysql-test/suite/sys_vars/r/all_vars.result | 1 + .../r/sysvars_innodb,32bit,xtradb.rdiff-disabled | 1236 +++++++++++ .../r/sysvars_innodb,xtradb.rdiff-disabled | 697 ++++++ mysql-test/suite/sys_vars/r/sysvars_wsrep.result | 14 + .../sys_vars/r/tmp_disk_table_size_func.result | 2 +- .../suite/sys_vars/t/tmp_disk_table_size_func.test | 1 - mysql-test/suite/vcol/inc/vcol_keys.inc | 1 - mysql-test/suite/vcol/r/vcol_keys_innodb.result | 2 +- mysys/mf_iocache2.c | 61 +- mysys/my_delete.c | 61 + mysys/my_file.c | 7 +- mysys/my_malloc.c | 1 + plugin/aws_key_management/CMakeLists.txt | 6 +- plugin/wsrep_info/mysql-test/wsrep_info/suite.pm | 2 + scripts/mysql_install_db.sh | 26 +- scripts/wsrep_sst_mariabackup.sh | 6 +- scripts/wsrep_sst_rsync.sh | 2 +- sql-common/client.c | 30 +- sql/field.cc | 4 +- sql/item.cc | 18 +- sql/item_func.cc | 2 +- sql/item_func.h | 4 + sql/log.cc | 6 +- sql/log_event.cc | 386 +++- sql/log_event.h | 24 +- sql/log_event_old.cc | 17 +- sql/partition_info.cc | 2 +- sql/rpl_tblmap.cc | 20 +- sql/rpl_tblmap.h | 10 +- sql/sql_binlog.cc | 91 +- sql/sql_class.cc | 23 +- sql/sql_class.h | 2 +- sql/sql_lex.cc | 3 +- sql/sql_lex.h | 4 + sql/sql_repl.cc | 6 +- sql/sql_select.cc | 21 +- sql/sql_table.cc | 142 +- sql/sql_yacc.yy | 19 +- sql/sql_yacc_ora.yy | 19 +- sql/sys_vars.cc | 13 + sql/table.cc | 2 +- sql/table.h | 12 +- sql/wsrep_mysqld.cc | 1 + sql/wsrep_mysqld.h | 1 + sql/wsrep_mysqld_c.h | 30 + storage/connect/ha_connect.cc | 45 +- storage/connect/jsonudf.cpp | 48 +- storage/connect/jsonudf.h | 5 + .../mysql-test/connect/r/jdbc_postgresql.result | 2 +- .../connect/mysql-test/connect/r/part_table.result | 4 +- .../connect/mysql-test/connect/t/part_table.test | 2 +- storage/connect/tabext.cpp | 43 +- storage/connect/tabext.h | 5 +- storage/connect/tabjdbc.cpp | 89 +- storage/connect/tabjson.cpp | 46 +- storage/connect/tabjson.h | 2 +- storage/connect/tabxml.cpp | 279 +-- storage/connect/tabxml.h | 1 + storage/innobase/dict/dict0dict.cc | 49 +- storage/innobase/handler/handler0alter.cc | 107 +- storage/innobase/handler/i_s.cc | 87 +- storage/innobase/include/trx0rseg.h | 4 +- storage/innobase/log/log0recv.cc | 2 +- storage/innobase/row/row0mysql.cc | 3 - storage/innobase/row/row0sel.cc | 43 +- storage/innobase/srv/srv0start.cc | 6 +- storage/maria/ma_delete.c | 2 - storage/maria/ma_write.c | 3 +- storage/maria/maria_def.h | 4 +- storage/tokudb/PerconaFT/COPYING.APACHEv2 | 174 ++ storage/tokudb/PerconaFT/README.md | 5 +- storage/tokudb/PerconaFT/ft/txn/txn_manager.h | 4 +- .../tokudb/PerconaFT/locktree/concurrent_tree.cc | 14 + .../tokudb/PerconaFT/locktree/concurrent_tree.h | 14 + storage/tokudb/PerconaFT/locktree/keyrange.cc | 13 + storage/tokudb/PerconaFT/locktree/keyrange.h | 13 + storage/tokudb/PerconaFT/locktree/lock_request.cc | 13 + storage/tokudb/PerconaFT/locktree/lock_request.h | 13 + storage/tokudb/PerconaFT/locktree/locktree.cc | 13 + storage/tokudb/PerconaFT/locktree/locktree.h | 13 + storage/tokudb/PerconaFT/locktree/manager.cc | 13 + storage/tokudb/PerconaFT/locktree/range_buffer.cc | 13 + storage/tokudb/PerconaFT/locktree/range_buffer.h | 13 + storage/tokudb/PerconaFT/locktree/treenode.cc | 13 + storage/tokudb/PerconaFT/locktree/treenode.h | 13 + storage/tokudb/PerconaFT/locktree/txnid_set.cc | 13 + storage/tokudb/PerconaFT/locktree/txnid_set.h | 13 + storage/tokudb/PerconaFT/locktree/wfg.cc | 13 + storage/tokudb/PerconaFT/locktree/wfg.h | 13 + .../PerconaFT/portability/toku_instr_mysql.cc | 12 +- .../PerconaFT/portability/toku_instr_mysql.h | 11 +- .../tokudb/PerconaFT/portability/toku_pthread.h | 78 +- storage/tokudb/PerconaFT/util/growable_array.h | 13 + storage/tokudb/PerconaFT/util/omt.cc | 2261 +++++++++++--------- storage/tokudb/PerconaFT/util/omt.h | 13 + storage/tokudb/ha_tokudb.cc | 10 + storage/tokudb/hatoku_hton.cc | 4 +- storage/tokudb/hatoku_hton.h | 1 - .../tokudb/mysql-test/tokudb_bugs/r/PS-4979.result | 2 + .../tokudb/mysql-test/tokudb_bugs/t/PS-4979.test | 13 + storage/tokudb/tokudb_background.cc | 4 +- storage/tokudb/tokudb_sysvars.cc | 14 +- storage/tokudb/tokudb_sysvars.h | 4 +- support-files/mysql.server.sh | 6 +- unittest/mysys/thr_template.c | 4 +- unittest/sql/mf_iocache-t.cc | 70 +- win/packaging/heidisql.cmake | 2 +- 209 files changed, 6128 insertions(+), 1947 deletions(-) diff --cc cmake/submodules.cmake index 9f04c26e8d6,34d1f37c956..c8f7b3cc400 --- a/cmake/submodules.cmake +++ b/cmake/submodules.cmake @@@ -31,7 -36,6 +36,6 @@@ ENDIF( IF(update_result OR NOT EXISTS ${CMAKE_SOURCE_DIR}/libmariadb/CMakeLists.txt) MESSAGE(FATAL_ERROR "No MariaDB Connector/C! Run - git submodule update --init --recursive - Then restart the build. - ") - ${GIT_EXECUTABLE} submodule update --init ++ ${GIT_EXECUTABLE} submodule update --init --recursive + Then restart the build.${SUBMODULE_UPDATE_CONFIG_MESSAGE}") ENDIF() diff --cc libmariadb index beb9d5ea899,2c5aebb3bc7..4aad20db15d --- a/libmariadb +++ b/libmariadb @@@ -1,1 -1,1 +1,1 @@@ - Subproject commit beb9d5ea8994bb90361c4b9f3d926eee24055178 -Subproject commit 2c5aebb3bc724c1663c481ba2fedde00ab494fa4 ++Subproject commit 4aad20db15d137009422416d53b2e0de5b819808 diff --cc mysql-test/main/disabled.def index eecee845a35,b6991cc1d37..c1cfd229a9b --- a/mysql-test/main/disabled.def +++ b/mysql-test/main/disabled.def @@@ -18,6 -21,4 +18,7 @@@ innodb-wl5522-debug-zip : broken upstr innodb_bug12902967 : broken upstream file_contents : MDEV-6526 these files are not installed anymore max_statement_time : cannot possibly work, depends on timing + partition_open_files_limit : open_files_limit check broken by MDEV-18360 +mysqlcheck : special tables like proxy , host specific to a system are shown +flush_read_lock : special tables like proxy , host specific to a system are shown +join_cache : enable after MDEV-17752 is fixed diff --cc mysql-test/main/subselect2.result index 21bf9aad122,cae0f2286c1..0e71f22e52e --- a/mysql-test/main/subselect2.result +++ b/mysql-test/main/subselect2.result @@@ -394,3 -394,25 +394,25 @@@ select null in (select a from t1 where (select a from t3) +1 < out3.a+1) from t3 out3; ERROR 21000: Subquery returns more than 1 row drop table t1, t2, t3; + CREATE TABLE t1( + q11 int, q12 int, q13 int, q14 int, q15 int, q16 int, q17 int, q18 int, q19 int, + q21 int, q22 int, q23 int, q24 int, q25 int, q26 int, q27 int, q28 int, q29 int, + f1 int + ); + CREATE TABLE t2(f2 int, f21 int, f3 timestamp, f4 int, f5 int, f6 int); + INSERT INTO t1 (f1) VALUES (1),(1),(2),(2); + INSERT INTO t2 VALUES (1,1,"2004-02-29 11:11:11",0,0,0), (2,2,"2004-02-29 11:11:11",0,0,0); + SELECT f1, + (SELECT t.f21 from t2 t where max( + q11+q12+q13+q14+q15+q16+q17+q18+q19+ + q21+q22+q23+q24+q25+q26+q27+q28+q29) = t.f2 UNION + SELECT t.f3 FROM t2 AS t WHERE t1.f1=t.f2 AND t.f3=MAX(t1.f1) UNION + SELECT 1 LIMIT 1) AS test + FROM t1 GROUP BY f1; + f1 test + 1 1 + 2 1 + Warnings: -Warning 1292 Incorrect datetime value: '1' -Warning 1292 Incorrect datetime value: '2' ++Warning 1292 Truncated incorrect datetime value: '1' ++Warning 1292 Truncated incorrect datetime value: '2' + DROP TABLE t1,t2; diff --cc mysql-test/main/subselect_sj2_mat.result index e4583cf6348,884451d7dff..f42b5ce1542 --- a/mysql-test/main/subselect_sj2_mat.result +++ b/mysql-test/main/subselect_sj2_mat.result @@@ -1743,10 -1701,10 +1743,10 @@@ O (t.id IN (0,4,12,13,1,10,3,11)) ); id select_type table type possible_keys key key_len ref rows Extra --1 PRIMARY t index PRIMARY PRIMARY 4 NULL 13 Using where; Using index ++1 PRIMARY t index PRIMARY PRIMARY 4 NULL 14 Using where; Using index 2 MATERIALIZED <subquery3> ALL distinct_key NULL NULL NULL 8 --2 MATERIALIZED A ALL PRIMARY NULL NULL NULL 13 Using where; Using join buffer (flat, BNL join) -3 MATERIALIZED B ALL PRIMARY NULL NULL NULL 13 Using where ++2 MATERIALIZED A ALL PRIMARY NULL NULL NULL 14 Using where; Using join buffer (flat, BNL join) +3 MATERIALIZED B range PRIMARY PRIMARY 4 NULL 8 Using where SELECT SQL_NO_CACHE t.id FROM t1 t WHERE ( diff --cc mysql-test/suite/encryption/t/innodb-spatial-index.test index a50ef306351,2bf56817740..0465225cd4f --- a/mysql-test/suite/encryption/t/innodb-spatial-index.test +++ b/mysql-test/suite/encryption/t/innodb-spatial-index.test @@@ -7,21 -6,10 +7,20 @@@ # # -# (1) Do not allow creating table with ENCRYPTED=YES # # ---error ER_CANT_CREATE_TABLE +let $checksum_algorithm = `SELECT @@innodb_checksum_algorithm`; +let $error_code = ER_CANT_CREATE_TABLE, ER_ILLEGAL_HA_CREATE_OPTION; +if ($checksum_algorithm == "full_crc32") +{ + let $error_code = 0; +} +if ($checksum_algorithm == "strict_full_crc32") +{ + let $error_code = 0; +} + - --replace_regex /#sql-[0-9a-f_]*`/#sql-temporary`/ +--error $error_code CREATE TABLE t1 (pk INT PRIMARY KEY AUTO_INCREMENT, c VARCHAR(256), coordinate POINT NOT NULL, SPATIAL index(coordinate)) ENGINE=INNODB ENCRYPTED=YES; @@@ -49,15 -30,14 +48,14 @@@ CREATE TABLE t1 (pk INT PRIMARY KEY AUT c VARCHAR(256), coordinate POINT NOT NULL) ENCRYPTED=YES ENGINE=INNODB; # FIXME: MDEV-13851 Encrypted table refuses some form of ALGORITHM=COPY, # but allows rebuild by FORCE - --replace_regex /#sql-[0-9a-f_]*`/#sql-temporary`/ ---error ER_CANT_CREATE_TABLE -ALTER TABLE t1 ADD SPATIAL INDEX b(coordinate), ALGORITHM=COPY; ---error ER_ILLEGAL_HA_CREATE_OPTION -ALTER TABLE t1 ADD SPATIAL INDEX b(coordinate), FORCE, ALGORITHM=INPLACE; ---error ER_ILLEGAL_HA_CREATE_OPTION +--error $error_code +ALTER TABLE t1 ADD SPATIAL INDEX b1(coordinate), ALGORITHM=COPY; +--error $error_code +ALTER TABLE t1 ADD SPATIAL INDEX b2(coordinate), FORCE, ALGORITHM=INPLACE; +--error $error_code ALTER TABLE t1 ADD SPATIAL INDEX(coordinate); ---error ER_ILLEGAL_HA_CREATE_OPTION -CREATE SPATIAL INDEX b on t1(coordinate); +--error $error_code +CREATE SPATIAL INDEX b3 on t1(coordinate); DROP TABLE t1; CREATE TABLE t1 (pk INT PRIMARY KEY AUTO_INCREMENT, diff --cc mysql-test/suite/galera_3nodes/galera_2x3nodes.cnf index 7aac1662edd,477789175fb..a0c7e64af91 --- a/mysql-test/suite/galera_3nodes/galera_2x3nodes.cnf +++ b/mysql-test/suite/galera_3nodes/galera_2x3nodes.cnf @@@ -9,7 -9,9 +9,8 @@@ innodb-autoinc-lock-mode= default-storage-engine=innodb wsrep_gtid_mode=1 gtid_ignore_duplicates + auto_increment_increment=3 -wsrep-on=1 wsrep-provider=@ENV.WSREP_PROVIDER wsrep_node_address=127.0.0.1 # enforce read-committed characteristics across the cluster diff --cc mysql-test/suite/galera_3nodes/galera_3nodes.cnf index ab7493e313b,e5aa81b8742..d33ed0caddf --- a/mysql-test/suite/galera_3nodes/galera_3nodes.cnf +++ b/mysql-test/suite/galera_3nodes/galera_3nodes.cnf @@@ -5,7 -5,9 +5,8 @@@ binlog-format=row innodb-autoinc-lock-mode=2 default-storage-engine=innodb + auto_increment_increment=3 -wsrep-on=1 wsrep-provider=@ENV.WSREP_PROVIDER wsrep_node_address=127.0.0.1 # enforce read-committed characteristics across the cluster diff --cc mysql-test/suite/galera_3nodes/r/galera_garbd.result index 88bb3ca2ff9,fb7e729dc77..1396179b871 --- a/mysql-test/suite/galera_3nodes/r/galera_garbd.result +++ b/mysql-test/suite/galera_3nodes/r/galera_garbd.result @@@ -1,10 -1,8 +1,18 @@@ ++<<<<<<< HEAD +connection node_2; +connection node_1; +connection node_1; +connection node_2; +connect node_3, 127.0.0.1, root, , test, $NODE_MYPORT_3; +connection node_3; ++||||||| merged common ancestors ++======= + connection node_1; + connection node_2; + connection node_3; ++>>>>>>> 10.3 Killing node #3 to free ports for garbd ... + connection node_3; connection node_1; Starting garbd ... CREATE TABLE t1 (f1 INTEGER); diff --cc mysql-test/suite/galera_3nodes/r/galera_var_dirty_reads2.result index 8e6d27823f6,77991a6d468..b0b5c8d26bd --- a/mysql-test/suite/galera_3nodes/r/galera_var_dirty_reads2.result +++ b/mysql-test/suite/galera_3nodes/r/galera_var_dirty_reads2.result @@@ -1,5 -1,7 +1,13 @@@ ++<<<<<<< HEAD +connection node_2; +connection node_1; ++||||||| merged common ancestors ++======= + connection node_1; + connection node_2; + connection node_3; + connection node_1; ++>>>>>>> 10.3 CREATE TABLE t1 (f1 INTEGER); INSERT INTO t1 VALUES (1); connection node_2; diff --cc mysql-test/suite/galera_3nodes/t/galera_garbd.test index 68e288c06c7,2d03e8897b9..cd401a5376a --- a/mysql-test/suite/galera_3nodes/t/galera_garbd.test +++ b/mysql-test/suite/galera_3nodes/t/galera_garbd.test @@@ -7,21 -7,20 +7,45 @@@ --source include/have_innodb.inc --source include/big_test.inc ++<<<<<<< HEAD +# Save galera ports +--connection node_1 +--source suite/galera/include/galera_base_port.inc +--let $NODE_GALERAPORT_1 = $_NODE_GALERAPORT + +--connection node_2 +--source suite/galera/include/galera_base_port.inc +--let $NODE_GALERAPORT_2 = $_NODE_GALERAPORT + +--connect node_3, 127.0.0.1, root, , test, $NODE_MYPORT_3 +--source suite/galera/include/galera_base_port.inc +--let $NODE_GALERAPORT_3 = $_NODE_GALERAPORT + +--connection node_3 +--echo Killing node #3 to free ports for garbd ... ++||||||| merged common ancestors ++--echo Killing node #3 to free ports for garbd ... ++--let $galera_connection_name = node_3 ++--let $galera_server_number = 3 ++--source include/galera_connect.inc ++--let $gp3 = `SELECT SUBSTR(@@wsrep_provider_options, LOCATE('base_port =', @@wsrep_provider_options) + LENGTH('base_port = '))` ++--let $galera_port_3 = `SELECT SUBSTR('$gp3', 1, LOCATE(';', '$gp3') - 1)` ++======= + --let $galera_connection_name = node_3 + --let $galera_server_number = 3 + --source include/galera_connect.inc + + # Save original auto_increment_offset values. + --let $node_1=node_1 + --let $node_2=node_2 + --let $node_3=node_3 + --source ../galera/include/auto_increment_offset_save.inc + + --echo Killing node #3 to free ports for garbd ... + --connection node_3 + --let $gp3 = `SELECT SUBSTR(@@wsrep_provider_options, LOCATE('base_port =', @@wsrep_provider_options) + LENGTH('base_port = '))` + --let $galera_port_3 = `SELECT SUBSTR('$gp3', 1, LOCATE(';', '$gp3') - 1)` ++>>>>>>> 10.3 --source include/shutdown_mysqld.inc --connection node_1 diff --cc mysql-test/suite/galera_3nodes/t/galera_var_dirty_reads2.test index 2ceda1ed352,e3f94a012b8..9f9d6da17b9 --- a/mysql-test/suite/galera_3nodes/t/galera_var_dirty_reads2.test +++ b/mysql-test/suite/galera_3nodes/t/galera_var_dirty_reads2.test @@@ -106,8 -117,10 +117,11 @@@ SET GLOBAL wsrep_provider_options='gmca --source include/wait_condition.inc --connection node_2 ---let $wait_condition = SELECT VARIABLE_VALUE = 'Primary' FROM INFORMATION_SCHEMA.GLOBAL_STATUS WHERE VARIABLE_NAME = 'wsrep_cluster_status'; +--let $wait_condition = SELECT VARIABLE_VALUE = 3 FROM INFORMATION_SCHEMA.GLOBAL_STATUS WHERE VARIABLE_NAME = 'wsrep_cluster_size'; --source include/wait_condition.inc +--source include/galera_wait_ready.inc DROP TABLE t1; + + # Restore original auto_increment_offset values. + --source ../galera/include/auto_increment_offset_restore.inc diff --cc mysql-test/suite/innodb/r/undo_truncate_recover.result index 018ac65537a,bcfc136e8c0..8ab41331950 --- a/mysql-test/suite/innodb/r/undo_truncate_recover.result +++ b/mysql-test/suite/innodb/r/undo_truncate_recover.result @@@ -9,6 -9,8 +9,7 @@@ update t1 set c = 'MariaDB' update t1 set c = 'InnoDB'; set global debug_dbug = '+d,ib_undo_trunc'; commit; + call mtr.add_suppression("InnoDB: innodb_undo_tablespaces=0 disables dedicated undo log tablespaces"); -call mtr.add_suppression("InnoDB: The redo log transaction size "); SET GLOBAL innodb_fast_shutdown=0; FOUND 1 /ib_undo_trunc/ in mysqld.1.err drop table t1; diff --cc mysql-test/suite/innodb/t/undo_truncate_recover.test index 5d680525c5b,c3fa698ff13..1da64497550 --- a/mysql-test/suite/innodb/t/undo_truncate_recover.test +++ b/mysql-test/suite/innodb/t/undo_truncate_recover.test @@@ -39,18 -38,14 +39,20 @@@ update t1 set c = 'MariaDB' update t1 set c = 'InnoDB'; eval set global debug_dbug = '+d,$SEARCH_PATTERN'; commit; + call mtr.add_suppression("InnoDB: innodb_undo_tablespaces=0 disables dedicated undo log tablespaces"); -# FIXME: remove this work-around, and generate less log! -call mtr.add_suppression("InnoDB: The redo log transaction size "); SET GLOBAL innodb_fast_shutdown=0; --source include/shutdown_mysqld.inc --source include/search_pattern_in_file.inc -# FIXME: remove this work-around, and generate less log! ---let $restart_parameters= --innodb-buffer-pool-size=16m --innodb-undo-tablespaces=1 ++--let $restart_parameters= --innodb-undo-tablespaces=1 +if ($checksum_algorithm == "strict_full_crc32") +{ - let $restart_parameters= --innodb_checksum_algorithm=strict_crc32; ++ let $restart_parameters= $restart_parameters --innodb_checksum_algorithm=strict_crc32; +} + +if ($checksum_algorithm == "strict_crc32") +{ - let $restart_parameters= --innodb_checksum_algorithm=strict_full_crc32; ++ let $restart_parameters= $restart_parameters --innodb_checksum_algorithm=strict_full_crc32; +} --source include/start_mysqld.inc drop table t1; diff --cc mysql-test/suite/perfschema/r/dml_setup_instruments.result index e43841c80ac,a5184782af8..a972cf02285 --- a/mysql-test/suite/perfschema/r/dml_setup_instruments.result +++ b/mysql-test/suite/perfschema/r/dml_setup_instruments.result @@@ -16,10 -16,11 +16,12 @@@ wait/synch/mutex/sql/LOCK_after_binlog_ wait/synch/mutex/sql/LOCK_audit_mask YES YES select * from performance_schema.setup_instruments where name like 'Wait/Synch/Rwlock/sql/%' - and name not in ('wait/synch/rwlock/sql/CRYPTO_dynlock_value::lock') + and name not in ( + 'wait/synch/rwlock/sql/CRYPTO_dynlock_value::lock', + 'wait/synch/rwlock/sql/LOCK_named_pipe_full_access_group') order by name limit 10; NAME ENABLED TIMED +wait/synch/rwlock/sql/LOCK_all_status_vars YES YES wait/synch/rwlock/sql/LOCK_dboptions YES YES wait/synch/rwlock/sql/LOCK_grant YES YES wait/synch/rwlock/sql/LOCK_SEQUENCE YES YES diff --cc plugin/aws_key_management/CMakeLists.txt index b6f48cd18a0,e9e1b49d5f2..90170746eb5 --- a/plugin/aws_key_management/CMakeLists.txt +++ b/plugin/aws_key_management/CMakeLists.txt @@@ -1,14 -1,174 +1,18 @@@ -# We build parts of AWS C++ SDK as CMake external project -# The restrictions of the SDK (https://github.com/awslabs/aws-sdk-cpp/blob/master/README.md) -# are - -# - OS : Windows,Linux or OSX -# - C++11 compiler : VS2013+, gcc 4.8+, clang 3.3+ -# - libcurl development package needs to be present on Unixes -# -# If we build SDK outselves, we'll need require GIT to be present on the build machine - - -# Give message why the building this plugin is skipped (only if -DVERBOSE is defined) -# or if plugin is explicitly requested to build. Then bail out. -MACRO(SKIP_AWS_PLUGIN msg) - MESSAGE_ONCE(SKIP_AWS_PLUGIN "Skip aws_key_management - ${msg}") +INCLUDE(aws_sdk) +CHECK_AWS_SDK(HAVE_AWS_SDK REASON) +IF(NOT HAVE_AWS_SDK) + MESSAGE_ONCE(AWS_KEY_MANAGEMENT_NO_AWS_SDK "Can't build aws_key_management - AWS SDK not available (${REASON})") RETURN() -ENDMACRO() -SET(CMAKE_CXX_STANDARD 11) - +ENDIF() + IF(NOT NOT_FOR_DISTRIBUTION) + SKIP_AWS_PLUGIN("AWS SDK has Apache 2.0 License which is not complatible with GPLv2. Set -DNOT_FOR_DISTRIBUTION=ON if you need this plugin") + ENDIF() -# This plugin needs recent C++ compilers (AWS C++ SDK header files are using C++11 features) -SET(CXX11_FLAGS) -SET(OLD_COMPILER_MSG "AWS SDK requires c++11 -capable compiler (minimal supported versions are g++ 4.8, clang 3.3, VS2103)") - -IF(CMAKE_CXX_COMPILER_ID MATCHES "GNU") - EXECUTE_PROCESS(COMMAND ${CMAKE_CXX_COMPILER} -dumpversion OUTPUT_VARIABLE GCC_VERSION) - IF (GCC_VERSION VERSION_LESS 4.8) - SKIP_AWS_PLUGIN("${OLD_COMPILER_MSG}") - ENDIF() - SET(CXX11_FLAGS "-std=c++11") -ELSEIF (CMAKE_CXX_COMPILER_ID MATCHES "Clang") - IF ((CMAKE_CXX_COMPILER_VERSION AND CMAKE_CXX_COMPILER_VERSION VERSION_LESS 3.3) OR - (CLANG_VERSION_STRING AND CLANG_VERSION_STRING VERSION_LESS 3.3)) - SKIP_AWS_PLUGIN("${OLD_COMPILER_MSG}") - ENDIF() - SET(CXX11_FLAGS "-stdlib=libc++") -ELSEIF(MSVC) - IF (MSVC_VERSION LESS 1800) - SKIP_AWS_PLUGIN("${OLD_COMPILER_MSG}") - ENDIF() -ELSE() - SKIP_AWS_PLUGIN("Compiler not supported by AWS C++ SDK") -ENDIF() - -IF (NOT(WIN32 OR APPLE OR (CMAKE_SYSTEM_NAME MATCHES "Linux"))) - SKIP_AWS_PLUGIN("OS unsupported by AWS SDK") -ENDIF() - - - -FIND_LIBRARY(AWS_CPP_SDK_CORE NAMES aws-cpp-sdk-core PATH_SUFFIXES "${SDK_INSTALL_BINARY_PREFIX}") -FIND_LIBRARY(AWS_CPP_SDK_KMS NAMES aws-cpp-sdk-kms PATH_SUFFIXES "${SDK_INSTALL_BINARY_PREFIX}") -FIND_PATH(AWS_CPP_SDK_INCLUDE_DIR NAMES aws/kms/KMSClient.h) - -IF(AWS_CPP_SDK_CORE AND AWS_CPP_SDK_KMS AND AWS_CPP_SDK_INCLUDE_DIR) - # AWS C++ SDK installed - INCLUDE_DIRECTORIES(${AWS_CPP_SDK_INCLUDE_DIR}) - SET(AWS_SDK_LIBS ${AWS_CPP_SDK_CORE} ${AWS_CPP_SDK_KMS}) -ELSE() - OPTION(AWS_SDK_EXTERNAL_PROJECT "Allow download and build AWS C++ SDK" OFF) - IF(NOT AWS_SDK_EXTERNAL_PROJECT) - SKIP_AWS_PLUGIN("AWS_SDK_EXTERNAL_PROJECT is not set") - ENDIF() - # Build from source, using ExternalProject_Add - # AWS C++ SDK requires cmake 2.8.12 - IF(CMAKE_VERSION VERSION_LESS "2.8.12") - SKIP_AWS_PLUGIN("CMake is too old") - ENDIF() - FIND_PACKAGE(Git) - IF(NOT GIT_FOUND) - SKIP_AWS_PLUGIN("no GIT") - ENDIF() - INCLUDE(ExternalProject) - IF(UNIX) - FIND_PACKAGE(CURL) - IF(NOT CURL_FOUND) - SKIP_AWS_PLUGIN("AWS C++ SDK requires libcurl development package") - ENDIF() - SET(PIC_FLAG -fPIC) - FIND_PATH(UUID_INCLUDE_DIR uuid/uuid.h) - IF(NOT UUID_INCLUDE_DIR) - SKIP_AWS_PLUGIN("AWS C++ SDK requires uuid development package") - ENDIF() - IF(NOT APPLE) - FIND_LIBRARY(UUID_LIBRARIES uuid) - IF(NOT UUID_LIBRARIES) - SKIP_AWS_PLUGIN("AWS C++ SDK requires uuid development package") - ENDIF() - FIND_PACKAGE(OpenSSL) - IF(NOT OPENSSL_FOUND) - SKIP_AWS_PLUGIN("AWS C++ SDK requires openssl development package") - ENDIF() - ENDIF() - ENDIF() - IF(MSVC) - SET(EXTRA_SDK_CMAKE_FLAGS -DCMAKE_CXX_FLAGS_DEBUGOPT="" -DCMAKE_EXE_LINKER_FLAGS_DEBUGOPT="" "-DCMAKE_CXX_FLAGS=/wd4530 /wd4577 /WX-") - ENDIF() - IF(CMAKE_CXX_COMPILER) - SET(EXTRA_SDK_CMAKE_FLAGS ${EXTRA_SDK_CMAKE_FLAGS} -DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER}) - ENDIF() - - SET(byproducts ) - # We do not need to build the whole SDK , just 2 of its libs - set(AWS_SDK_LIBS aws-cpp-sdk-core aws-cpp-sdk-kms) - FOREACH(lib ${AWS_SDK_LIBS}) - ADD_LIBRARY(${lib} STATIC IMPORTED GLOBAL) - ADD_DEPENDENCIES(${lib} aws_sdk_cpp) - SET(loc "${CMAKE_CURRENT_BINARY_DIR}/aws_sdk_cpp/lib/${CMAKE_STATIC_LIBRARY_PREFIX}${lib}${CMAKE_STATIC_LIBRARY_SUFFIX}") - IF(CMAKE_VERSION VERSION_GREATER "3.1") - SET(byproducts ${byproducts} BUILD_BYPRODUCTS ${loc}) - ENDIF() - SET_TARGET_PROPERTIES(${lib} PROPERTIES IMPORTED_LOCATION ${loc}) - ENDFOREACH() - - # To be compatible with older cmake, we use older version of the SDK - IF(CMAKE_VERSION LESS "3.0") - SET(GIT_TAG "1.0.8") - ELSE() - SET(GIT_TAG "1.2.11") - ENDIF() - - SET(AWS_SDK_PATCH_COMMAND ) - ExternalProject_Add( - aws_sdk_cpp - GIT_REPOSITORY "https://github.com/awslabs/aws-sdk-cpp.git" - GIT_TAG ${GIT_TAG} - UPDATE_COMMAND "" - SOURCE_DIR "${CMAKE_CURRENT_BINARY_DIR}/aws-sdk-cpp" - ${byproducts} - CMAKE_ARGS - -DBUILD_ONLY=kms - -DBUILD_SHARED_LIBS=OFF - -DFORCE_SHARED_CRT=OFF - -DENABLE_TESTING=OFF - "-DCMAKE_CXX_FLAGS_DEBUG=${CMAKE_CXX_FLAGS_DEBUG} ${PIC_FLAG}" - "-DCMAKE_CXX_FLAGS_RELWITHDEBINFO=${CMAKE_CXX_FLAGS_RELWITHDEBINFO} ${PIC_FLAG}" - "-DCMAKE_CXX_FLAGS_RELEASE=${CMAKE_CXX_FLAGS_RELEASE} ${PIC_FLAG}" - "-DCMAKE_CXX_FLAGS_MINSIZEREL=${CMAKE_CXX_FLAGS_MINSIZEREL} ${PIC_FLAG}" - ${EXTRA_SDK_CMAKE_FLAGS} - -DCMAKE_INSTALL_PREFIX=${CMAKE_CURRENT_BINARY_DIR}/aws_sdk_cpp - -DCMAKE_INSTALL_LIBDIR=lib - TEST_COMMAND "" - ) - SET_TARGET_PROPERTIES(aws_sdk_cpp PROPERTIES EXCLUDE_FROM_ALL TRUE) - - IF(CMAKE_SYSTEM_NAME MATCHES "Linux") - # Need whole-archive , otherwise static libraries are not linked - SET(AWS_SDK_LIBS -Wl,--whole-archive ${AWS_SDK_LIBS} -Wl,--no-whole-archive) - ENDIF() - SET_TARGET_PROPERTIES(aws_sdk_cpp PROPERTIES EXCLUDE_FROM_ALL TRUE) - INCLUDE_DIRECTORIES(${CMAKE_CURRENT_BINARY_DIR}/aws_sdk_cpp/include) -ENDIF() - -ADD_DEFINITIONS(${SSL_DEFINES}) # Need to know whether openssl should be initialized -IF(CMAKE_VERSION GREATER "3.0") - SET(CMAKE_CXX_STANDARD 11) -ELSE() - SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${CXX11_FLAGS}") -ENDIF() -IF(WIN32) - SET(AWS_CPP_SDK_DEPENDENCIES bcrypt winhttp wininet userenv version) -ELSE() - SET(AWS_CPP_SDK_DEPENDENCIES ${OPENSSL_LIBRARIES} ${CURL_LIBRARIES} ${UUID_LIBRARIES}) -ENDIF() -MYSQL_ADD_PLUGIN(aws_key_management aws_key_management_plugin.cc - LINK_LIBRARIES ${AWS_SDK_LIBS} ${AWS_CPP_SDK_DEPENDENCIES} - COMPONENT aws-key-management) +MYSQL_ADD_PLUGIN(aws_key_management + aws_key_management_plugin.cc + COMPONENT aws-key-management) -IF (TARGET aws_key_management) - SET(NON_DISTRIBUTABLE_WARNING "Apache 2.0" PARENT_SCOPE) +IF(TARGET aws_key_management) ++ SET(NON_DISTRIBUTABLE_WARNING "Apache 2.0" PARENT_SCOPE) + USE_AWS_SDK_LIBS(aws_key_management kms) - ENDIF() + ENDIF() diff --cc scripts/mysql_install_db.sh index 54b5bed4546,52107405525..06c03dfcb40 --- a/scripts/mysql_install_db.sh +++ b/scripts/mysql_install_db.sh @@@ -37,10 -37,13 +37,13 @@@ force= in_rpm=0 ip_only=0 cross_bootstrap=0 -auth_root_authentication_method=normal -auth_root_socket_user='root' +auth_root_authentication_method=socket +auth_root_socket_user="" skip_test_db=0 + dirname0=`dirname $0 2>/dev/null` + dirname0=`dirname $dirname0 2>/dev/null` + usage() { cat <<EOF @@@ -343,7 -345,16 +346,18 @@@ the exit 1 fi plugindir=`find_in_dirs --dir auth_socket.so $basedir/lib*/plugin $basedir/lib*/mysql/plugin` + pamtooldir=$plugindir + # relative from where the script was run for a relocatable install + elif test -n "$dirname0" -a -x "$rel_mysqld" -a ! "$rel_mysqld" -ef "@sbindir@/mysqld" + then + basedir="$dirname0" + bindir="$basedir/@INSTALL_BINDIR@" + resolveip="$bindir/resolveip" + mysqld="$rel_mysqld" + srcpkgdatadir="$basedir/@INSTALL_MYSQLSHAREDIR@" + buildpkgdatadir="$basedir/@INSTALL_MYSQLSHAREDIR@" + plugindir="$basedir/@INSTALL_PLUGINDIR@" ++ pamtooldir=$plugindir else basedir="@prefix@" bindir="@bindir@" @@@ -352,7 -363,6 +366,7 @@@ srcpkgdatadir="@pkgdatadir@" buildpkgdatadir="@pkgdatadir@" plugindir="@pkgplugindir@" - pamtooldir="@pkgplugindir@" ++ pamtooldir=$plugindir fi # Set up paths to SQL scripts required for bootstrap diff --cc sql-common/client.c index 69404e43613,160a85fd7b5..c66cb1a749d --- a/sql-common/client.c +++ b/sql-common/client.c @@@ -1375,10 -1634,16 +1381,12 @@@ mysql_init(MYSQL *mysql --enable-local-infile */ - #if defined(ENABLED_LOCAL_INFILE) && !defined(MYSQL_SERVER) + #if ENABLED_LOCAL_INFILE && !defined(MYSQL_SERVER) mysql->options.client_flag|= CLIENT_LOCAL_FILES; + mysql->auto_local_infile= ENABLED_LOCAL_INFILE == LOCAL_INFILE_MODE_AUTO + ? WAIT_FOR_QUERY : ALWAYS_ACCEPT; #endif -#ifdef HAVE_SMEM - mysql->options.shared_memory_base_name= (char*) def_shared_memory_base_name; -#endif - mysql->options.methods_to_use= MYSQL_OPT_GUESS_CONNECTION; mysql->options.report_data_truncation= TRUE; /* default */ diff --cc sql/item.cc index a6b4402b6ba,ada79fcb9df..47e10ba4004 --- a/sql/item.cc +++ b/sql/item.cc @@@ -1950,9 -2195,34 +1950,14 @@@ bool Item_name_const::is_null( Item_name_const::Item_name_const(THD *thd, Item *name_arg, Item *val): - Item(thd), value_item(val), name_item(name_arg) + Item_fixed_hybrid(thd), value_item(val), name_item(name_arg) { + StringBuffer<128> name_buffer; + String *name_str; Item::maybe_null= TRUE; - valid_args= true; - if (!name_item->basic_const_item() || - !(name_str= name_item->val_str(&name_buffer))) // Can't have a NULL name - goto err; - set_name(thd, name_str->ptr(), name_str->length(), name_str->charset()); - - if (value_item->basic_const_item()) - return; // ok - - if (value_item->type() == FUNC_ITEM) - { - Item_func *value_func= (Item_func *) value_item; - if (value_func->functype() != Item_func::COLLATE_FUNC && - value_func->functype() != Item_func::NEG_FUNC) - goto err; - - if (value_func->key_item()->basic_const_item()) - return; // ok - } - -err: - valid_args= false; - my_error(ER_WRONG_ARGUMENTS, MYF(0), "NAME_CONST"); ++ if (name_item->basic_const_item() && ++ (name_str= name_item->val_str(&name_buffer))) // Can't have a NULL name ++ set_name(thd, name_str->ptr(), name_str->length(), name_str->charset()); } @@@ -1988,16 -2266,12 +1993,10 @@@ Item::Type Item_name_const::type() cons bool Item_name_const::fix_fields(THD *thd, Item **ref) { - char buf[128]; - String *item_name; - String s(buf, sizeof(buf), &my_charset_bin); - s.length(0); - - if ((!value_item->fixed && - value_item->fix_fields(thd, &value_item)) || - (!name_item->fixed && - name_item->fix_fields(thd, &name_item)) || + if (value_item->fix_fields_if_needed(thd, &value_item) || + name_item->fix_fields_if_needed(thd, &name_item) || !value_item->const_item() || - !name_item->const_item() || - !(item_name= name_item->val_str(&s))) // Can't have a NULL name + !name_item->const_item()) { my_error(ER_RESERVED_SYNTAX, MYF(0), "NAME_CONST"); return TRUE; diff --cc sql/sql_binlog.cc index 1fa3cca7c27,60de2923a8f..97b8e2e4f91 --- a/sql/sql_binlog.cc +++ b/sql/sql_binlog.cc @@@ -109,6 -109,64 +109,64 @@@ static int check_event_type(int type, R } } + /** + Copy fragments into the standard placeholder thd->lex->comment.str. + + Compute the size of the (still) encoded total, + allocate and then copy fragments one after another. + The size can exceed max(max_allowed_packet) which is not a + problem as no String instance is created off this char array. + + @param thd THD handle + @return + 0 at success, + -1 otherwise. + */ + int binlog_defragment(THD *thd) + { + user_var_entry *entry[2]; + LEX_CSTRING name[2]= { thd->lex->comment, thd->lex->ident }; + + /* compute the total size */ + thd->lex->comment.str= NULL; + thd->lex->comment.length= 0; + for (uint k= 0; k < 2; k++) + { + entry[k]= + (user_var_entry*) my_hash_search(&thd->user_vars, (uchar*) name[k].str, + name[k].length); + if (!entry[k] || entry[k]->type != STRING_RESULT) + { + my_error(ER_WRONG_TYPE_FOR_VAR, MYF(0), name[k].str); + return -1; + } + thd->lex->comment.length += entry[k]->length; + } + + thd->lex->comment.str= // to be freed by the caller + (char *) my_malloc(thd->lex->comment.length, MYF(MY_WME)); + if (!thd->lex->comment.str) + { - my_error(ER_OUTOFMEMORY, MYF(ME_FATALERROR), 1); ++ my_error(ER_OUTOFMEMORY, MYF(ME_FATAL), 1); + return -1; + } + + /* fragments are merged into allocated buf while the user var:s get reset */ + size_t gathered_length= 0; + for (uint k=0; k < 2; k++) + { + memcpy(const_cast<char*>(thd->lex->comment.str) + gathered_length, entry[k]->value, + entry[k]->length); + gathered_length += entry[k]->length; + update_hash(entry[k], true, NULL, 0, STRING_RESULT, &my_charset_bin, 0); + } + + DBUG_ASSERT(gathered_length == thd->lex->comment.length); + + return 0; + } + + /** Execute a BINLOG statement. @@@ -171,14 -223,31 +223,31 @@@ void mysql_client_binlog_statement(THD /* Out of memory check */ - if (!(rli && buf)) + if (!(rli)) { - my_error(ER_OUTOFMEMORY, MYF(ME_FATALERROR), 1); /* needed 1 bytes */ + my_error(ER_OUTOFMEMORY, MYF(ME_FATAL), 1); /* needed 1 bytes */ goto end; } DBUG_ASSERT(rli->belongs_to_client()); + if (unlikely(is_fragmented= thd->lex->comment.str && thd->lex->ident.str)) + if (binlog_defragment(thd)) + goto end; + + if (!(coded_len= thd->lex->comment.length)) + { + my_error(ER_SYNTAX_ERROR, MYF(0)); + goto end; + } + + decoded_len= my_base64_needed_decoded_length((int)coded_len); + if (!(buf= (char *) my_malloc(decoded_len, MYF(MY_WME)))) + { - my_error(ER_OUTOFMEMORY, MYF(ME_FATALERROR), 1); ++ my_error(ER_OUTOFMEMORY, MYF(ME_FATAL), 1); + goto end; + } + for (char const *strptr= thd->lex->comment.str ; strptr < thd->lex->comment.str + thd->lex->comment.length ; ) { diff --cc sql/sql_class.h index 88494f8c169,b1fc89db7f2..361340ee235 --- a/sql/sql_class.h +++ b/sql/sql_class.h @@@ -4420,80 -4375,6 +4420,80 @@@ private return raised; } +private: + void push_warning_truncated_priv(Sql_condition::enum_warning_level level, + uint sql_errno, + const char *type_str, const char *val) + { + DBUG_ASSERT(sql_errno == ER_TRUNCATED_WRONG_VALUE || + sql_errno == ER_WRONG_VALUE); + char buff[MYSQL_ERRMSG_SIZE]; + CHARSET_INFO *cs= &my_charset_latin1; + cs->cset->snprintf(cs, buff, sizeof(buff), + ER_THD(this, sql_errno), type_str, val); + /* + Note: the format string can vary between ER_TRUNCATED_WRONG_VALUE + and ER_WRONG_VALUE, but the code passed to push_warning() is + always ER_TRUNCATED_WRONG_VALUE. This is intentional. + */ + push_warning(this, level, ER_TRUNCATED_WRONG_VALUE, buff); + } +public: + void push_warning_truncated_wrong_value(Sql_condition::enum_warning_level level, + const char *type_str, const char *val) + { + return push_warning_truncated_priv(level, ER_TRUNCATED_WRONG_VALUE, + type_str, val); + } + void push_warning_wrong_value(Sql_condition::enum_warning_level level, + const char *type_str, const char *val) + { + return push_warning_truncated_priv(level, ER_WRONG_VALUE, type_str, val); + } + void push_warning_truncated_wrong_value(const char *type_str, const char *val) + { + return push_warning_truncated_wrong_value(Sql_condition::WARN_LEVEL_WARN, + type_str, val); + } + void push_warning_truncated_value_for_field(Sql_condition::enum_warning_level + level, const char *type_str, + const char *val, + const TABLE_SHARE *s, + const char *name) + { + DBUG_ASSERT(name); + char buff[MYSQL_ERRMSG_SIZE]; + CHARSET_INFO *cs= &my_charset_latin1; + const char *db_name= s ? s->db.str : NULL; - const char *table_name= s ? s->error_table_name() : NULL; ++ const char *table_name= s ? s->table_name.str : NULL; + + if (!db_name) + db_name= ""; + if (!table_name) + table_name= ""; + cs->cset->snprintf(cs, buff, sizeof(buff), + ER_THD(this, ER_TRUNCATED_WRONG_VALUE_FOR_FIELD), + type_str, val, db_name, table_name, name, + (ulong) get_stmt_da()->current_row_for_warning()); + push_warning(this, level, ER_TRUNCATED_WRONG_VALUE, buff); + + } + void push_warning_wrong_or_truncated_value(Sql_condition::enum_warning_level level, + bool totally_useless_value, + const char *type_str, + const char *val, + const TABLE_SHARE *s, + const char *field_name) + { + if (field_name) + push_warning_truncated_value_for_field(level, type_str, val, + s, field_name); + else if (totally_useless_value) + push_warning_wrong_value(level, type_str, val); + else + push_warning_truncated_wrong_value(level, type_str, val); + } + public: /** Overloaded to guard query/query_length fields */ virtual void set_statement(Statement *stmt); diff --cc sql/sql_repl.cc index 59f6a45a52f,fdca609f5af..647f83c31e7 --- a/sql/sql_repl.cc +++ b/sql/sql_repl.cc @@@ -547,19 -556,29 +547,19 @@@ static my_bool adjust_callback(THD *thd } -bool log_in_use(const char* log_name) +void adjust_linfo_offsets(my_off_t purge_offset) { - size_t log_name_len = strlen(log_name) + 1; - THD *tmp; - bool result = 0; + server_threads.iterate(adjust_callback, &purge_offset); +} - mysql_mutex_lock(&LOCK_thread_count); - I_List_iterator<THD> it(threads); - while ((tmp=it++)) - { - LOG_INFO* linfo; - if ((linfo = tmp->current_linfo)) - { - mysql_mutex_lock(&linfo->lock); - result = !strncmp(log_name, linfo->log_file_name, log_name_len); - mysql_mutex_unlock(&linfo->lock); - if (result) - break; - } - } - - mysql_mutex_unlock(&LOCK_thread_count); +static my_bool log_in_use_callback(THD *thd, const char *log_name) +{ + my_bool result= 0; + mysql_mutex_lock(&thd->LOCK_thd_data); + if (auto linfo= thd->current_linfo) - result= !memcmp(log_name, linfo->log_file_name, strlen(log_name) + 1); ++ result= !strncmp(log_name, linfo->log_file_name, strlen(log_name) + 1); + mysql_mutex_unlock(&thd->LOCK_thd_data); return result; } diff --cc sql/sql_table.cc index 4dd9d43a7b9,7f2003b765b..af92bc43c59 --- a/sql/sql_table.cc +++ b/sql/sql_table.cc @@@ -9762,12 -9818,11 +9786,12 @@@ do_continue: /* Mark that we have created table in storage engine. */ no_ha_table= false; - new_table= - thd->create_and_open_tmp_table(new_db_type, &frm, alter_ctx.get_tmp_path(), - alter_ctx.new_db.str, - alter_ctx.new_name.str, - true, true); + /* Open the table since we need to copy the data. */ + new_table= thd->create_and_open_tmp_table(new_db_type, &frm, + alter_ctx.get_tmp_path(), + alter_ctx.new_db.str, - alter_ctx.tmp_name.str, ++ alter_ctx.new_name.str, + true, true); if (!new_table) goto err_new_table_cleanup; @@@ -10687,9 -10732,12 +10710,12 @@@ bool mysql_checksum_table(THD *thd, TAB { /* calculating table's checksum */ ha_checksum crc= 0; - uchar null_mask=256 - (1 << t->s->last_null_bit_pos); + DBUG_ASSERT(t->s->last_null_bit_pos < 8); + uchar null_mask= (t->s->last_null_bit_pos ? + (256 - (1 << t->s->last_null_bit_pos)): + 0); - t->use_all_columns(); + t->use_all_stored_columns(); if (t->file->ha_rnd_init(1)) protocol->store_null(); diff --cc sql/table.cc index 7682119c241,10543a1b4f0..75f5a464186 --- a/sql/table.cc +++ b/sql/table.cc @@@ -5449,8 -5292,8 +5449,8 @@@ int TABLE::verify_constraints(bool igno } field_error.append((*chk)->name.str); my_error(ER_CONSTRAINT_FAILED, - MYF(ignore_failure ? ME_JUST_WARNING : 0), field_error.c_ptr(), + MYF(ignore_failure ? ME_WARNING : 0), field_error.c_ptr(), - s->db.str, s->error_table_name()); + s->db.str, s->table_name.str); return ignore_failure ? VIEW_CHECK_SKIP : VIEW_CHECK_ERROR; } } diff --cc sql/wsrep_mysqld.h index dc2793c384d,cca66922a24..d12cc835136 --- a/sql/wsrep_mysqld.h +++ b/sql/wsrep_mysqld.h @@@ -20,25 -23,15 +20,26 @@@ #ifdef WITH_WSREP +#include <mysql/plugin.h> +#include "mysql/service_wsrep.h" + +#include <my_global.h> +#include <my_pthread.h> +#include "log.h" +#include "mysqld.h" + typedef struct st_mysql_show_var SHOW_VAR; #include <sql_priv.h> -//#include "rpl_gtid.h" -#include "../wsrep/wsrep_api.h" #include "mdl.h" -#include "mysqld.h" #include "sql_table.h" + #include "wsrep_mysqld_c.h" +#include "wsrep/provider.hpp" +#include "wsrep/streaming_context.hpp" +#include "wsrep_api.h" +#include <vector> +#include "wsrep_server_state.h" + #define WSREP_UNDEFINED_TRX_ID ULONGLONG_MAX class set_var; diff --cc storage/innobase/handler/handler0alter.cc index 307374ec700,d3907f2d05e..b1dc295206a --- a/storage/innobase/handler/handler0alter.cc +++ b/storage/innobase/handler/handler0alter.cc @@@ -10176,12 -9087,12 +10191,13 @@@ commit_try_norebuild after a successful commit_try_norebuild() call. @param ha_alter_info algorithm=inplace context @param ctx In-place ALTER TABLE context for the current partition +@param altered_table the TABLE after the ALTER @param table the TABLE before the ALTER @param trx Data dictionary transaction - (will be started and committed, for DROP INDEX) */ + (will be started and committed, for DROP INDEX) + @return whether all replacements were found for dropped indexes */ inline MY_ATTRIBUTE((nonnull)) - void + bool commit_cache_norebuild( /*===================*/ Alter_inplace_info* ha_alter_info, @@@ -11009,12 -9869,20 +11015,21 @@@ foreign_fail m_user_thd, Sql_condition::WARN_LEVEL_WARN, ER_ALTER_INFO, - "InnoDB: Could not add foreign" - " key constraints."); - } else { - commit_cache_norebuild(ha_alter_info, ctx, - altered_table, - table, trx); + "failed to load FOREIGN KEY" + " constraints"); + } + } else { + bool fk_fail = innobase_update_foreign_cache( + ctx, m_user_thd) != DB_SUCCESS; + - if (!commit_cache_norebuild(ha_alter_info, ctx, table, ++ if (!commit_cache_norebuild(ha_alter_info, ctx, ++ altered_table, table, + trx)) { + fk_fail = true; + } + + if (fk_fail && m_prebuilt->trx->check_foreigns) { + goto foreign_fail; } }
participants (1)
-
Oleksandr Byelkin