mirror of
https://github.com/MariaDB/server.git
synced 2025-11-28 17:36:30 +03:00
Merge 10.4 into 10.5
This commit is contained in:
@@ -104,6 +104,17 @@ Note 1592 Unsafe statement written to the binary log using statement format sinc
|
||||
SHOW WARNINGS;
|
||||
Level Code Message
|
||||
Note 1592 Unsafe statement written to the binary log using statement format since BINLOG_FORMAT = STATEMENT. Statement is unsafe because it invokes a trigger or a stored function that inserts into an AUTO_INCREMENT column. Inserted values cannot be logged correctly
|
||||
CREATE TABLE t3 (a INT(11) DEFAULT NULL);
|
||||
INSERT INTO t3 VALUES (1);
|
||||
CREATE TABLE t4 (a INT(11) DEFAULT NULL, b BIGINT(20) DEFAULT uuid_short()) SELECT * FROM t3;
|
||||
Warnings:
|
||||
Note 1592 Unsafe statement written to the binary log using statement format since BINLOG_FORMAT = STATEMENT. Statement is unsafe because it uses a system function that may return a different value on the slave
|
||||
SHOW WARNINGS;
|
||||
Level Code Message
|
||||
Note 1592 Unsafe statement written to the binary log using statement format since BINLOG_FORMAT = STATEMENT. Statement is unsafe because it uses a system function that may return a different value on the slave
|
||||
CREATE OR REPLACE TABLE t4 (a INT(11) DEFAULT NULL) SELECT * FROM t3;
|
||||
SHOW WARNINGS;
|
||||
Level Code Message
|
||||
DROP FUNCTION sf_bug50192;
|
||||
DROP TRIGGER tr_bug50192;
|
||||
DROP TABLE t1, t2;
|
||||
DROP TABLE t1, t2, t3, t4;
|
||||
|
||||
@@ -0,0 +1,33 @@
|
||||
call mtr.add_suppression("Unsafe statement written to the binary log using statement format since BINLOG_FORMAT = STATEMENT");
|
||||
select @@innodb_autoinc_lock_mode;
|
||||
@@innodb_autoinc_lock_mode
|
||||
2
|
||||
select @@binlog_format;
|
||||
@@binlog_format
|
||||
MIXED
|
||||
create table t1 (a int not null auto_increment,b int, primary key (a)) engine=InnoDB;
|
||||
insert into t1 values (NULL,1);
|
||||
include/show_binlog_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
master-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
master-bin.000001 # Query # # use `mtr`; INSERT INTO test_suppressions (pattern) VALUES ( NAME_CONST('pattern',_latin1'Unsafe statement written to the binary log using statement format since BINLOG_FORMAT = STATEMENT' COLLATE 'latin1_swedish_ci'))
|
||||
master-bin.000001 # Query # # COMMIT
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; create table t1 (a int not null auto_increment,b int, primary key (a)) engine=InnoDB
|
||||
master-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
master-bin.000001 # Annotate_rows # # insert into t1 values (NULL,1)
|
||||
master-bin.000001 # Table_map # # table_id: # (test.t1)
|
||||
master-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||
master-bin.000001 # Xid # # COMMIT /* XID */
|
||||
set global binlog_format=STATEMENT;
|
||||
connect con1,localhost,root,,test,$MASTER_MYPORT,$MASTER_MYSOCK;
|
||||
insert into t1 values (NULL,1);
|
||||
Warnings:
|
||||
Note 1592 Unsafe statement written to the binary log using statement format since BINLOG_FORMAT = STATEMENT. Statement is unsafe because it uses a system variable that may have a different value on the slave
|
||||
insert into t1 values (NULL,1);
|
||||
Warnings:
|
||||
Note 1592 Unsafe statement written to the binary log using statement format since BINLOG_FORMAT = STATEMENT. Statement is unsafe because it uses a system variable that may have a different value on the slave
|
||||
disconnect con1;
|
||||
connection default;
|
||||
set global binlog_format=MIXED;
|
||||
DROP TABLE t1;
|
||||
@@ -189,8 +189,20 @@ SHOW WARNINGS;
|
||||
SELECT sf_bug50192();
|
||||
SHOW WARNINGS;
|
||||
|
||||
# The test proves MDEV-24617 fixes leave in force
|
||||
# unsafe warnings in non-deterministic CREATE..SELECT cases.
|
||||
# Below an inserted default value to `b` of the target table is replication
|
||||
# unsafe. A warning must be out.
|
||||
CREATE TABLE t3 (a INT(11) DEFAULT NULL);
|
||||
INSERT INTO t3 VALUES (1);
|
||||
CREATE TABLE t4 (a INT(11) DEFAULT NULL, b BIGINT(20) DEFAULT uuid_short()) SELECT * FROM t3;
|
||||
SHOW WARNINGS;
|
||||
# no warning out of a deterministic "rhs" of SELECT
|
||||
CREATE OR REPLACE TABLE t4 (a INT(11) DEFAULT NULL) SELECT * FROM t3;
|
||||
SHOW WARNINGS;
|
||||
|
||||
# cleanup
|
||||
|
||||
DROP FUNCTION sf_bug50192;
|
||||
DROP TRIGGER tr_bug50192;
|
||||
DROP TABLE t1, t2;
|
||||
DROP TABLE t1, t2, t3, t4;
|
||||
|
||||
@@ -0,0 +1 @@
|
||||
--innodb_autoinc_lock_mode=2
|
||||
@@ -0,0 +1,21 @@
|
||||
--source include/have_innodb.inc
|
||||
--source include/have_binlog_format_mixed.inc
|
||||
|
||||
call mtr.add_suppression("Unsafe statement written to the binary log using statement format since BINLOG_FORMAT = STATEMENT");
|
||||
|
||||
select @@innodb_autoinc_lock_mode;
|
||||
select @@binlog_format;
|
||||
|
||||
create table t1 (a int not null auto_increment,b int, primary key (a)) engine=InnoDB;
|
||||
insert into t1 values (NULL,1);
|
||||
--source include/show_binlog_events.inc
|
||||
|
||||
set global binlog_format=STATEMENT;
|
||||
--connect (con1,localhost,root,,test,$MASTER_MYPORT,$MASTER_MYSOCK)
|
||||
insert into t1 values (NULL,1);
|
||||
insert into t1 values (NULL,1);
|
||||
--disconnect con1
|
||||
--connection default
|
||||
|
||||
set global binlog_format=MIXED;
|
||||
DROP TABLE t1;
|
||||
Reference in New Issue
Block a user