mirror of
https://github.com/MariaDB/server.git
synced 2025-10-24 16:38:14 +02:00
245 lines
6.1 KiB
Text
245 lines
6.1 KiB
Text
##
|
|
## Tests the auto-increment with binlog in STATEMENT mode.
|
|
##
|
|
|
|
--source include/galera_cluster.inc
|
|
--source include/force_restart.inc
|
|
|
|
--let $node_1=node_1
|
|
--let $node_2=node_2
|
|
--source include/auto_increment_offset_save.inc
|
|
|
|
--connection node_1
|
|
SET GLOBAL auto_increment_offset=1;
|
|
--connection node_2
|
|
SET GLOBAL auto_increment_offset=2;
|
|
|
|
##
|
|
## Verify the correct operation of the auto-increment when the binlog
|
|
## format artificially set to the 'STATEMENT' (although this mode is
|
|
## not recommended in the current version):
|
|
##
|
|
|
|
--connection node_2
|
|
SET GLOBAL wsrep_forced_binlog_format='STATEMENT';
|
|
|
|
--disable_query_log
|
|
call mtr.add_suppression("Unsafe statement written to the binary log");
|
|
--enable_query_log
|
|
|
|
--connection node_1
|
|
SET GLOBAL wsrep_forced_binlog_format='STATEMENT';
|
|
|
|
--disable_query_log
|
|
call mtr.add_suppression("Unsafe statement written to the binary log");
|
|
--enable_query_log
|
|
|
|
CREATE TABLE t1 (
|
|
i int(11) NOT NULL primary key AUTO_INCREMENT,
|
|
c char(32) DEFAULT 'dummy_text'
|
|
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
|
|
|
|
show variables like 'auto_increment%';
|
|
insert into t1(i) values(null);
|
|
|
|
select * from t1 order by i;
|
|
|
|
insert into t1(i) values(null), (null), (null);
|
|
|
|
select * from t1 order by i;
|
|
|
|
--connection node_2
|
|
--let $wait_condition = SELECT COUNT(*) = 4 FROM t1;
|
|
--source include/wait_condition.inc
|
|
show variables like 'auto_increment%';
|
|
select * from t1 order by i;
|
|
|
|
SET GLOBAL wsrep_forced_binlog_format='none';
|
|
|
|
--connection node_1
|
|
|
|
SET GLOBAL wsrep_forced_binlog_format='none';
|
|
|
|
drop table t1;
|
|
|
|
##
|
|
## Check the operation when the automatic control over the auto-increment
|
|
## settings is switched off, that is, when we use the increment step and
|
|
## the offset specified by the user. In the current session, the binlog
|
|
## format is set to 'STATEMENT'. It is important that the values of the
|
|
## auto-increment options does not changed on other node - it allows us
|
|
## to check the correct transmission of the auto-increment options to
|
|
## other nodes:
|
|
##
|
|
|
|
--disable_warnings
|
|
SET SESSION binlog_format='STATEMENT';
|
|
--enable_warnings
|
|
|
|
show variables like 'binlog_format';
|
|
|
|
SET GLOBAL wsrep_auto_increment_control='OFF';
|
|
|
|
let $increment_node1 = `SELECT @@session.auto_increment_increment`;
|
|
let $offset_node1 = `SELECT @@session.auto_increment_offset`;
|
|
SET SESSION auto_increment_increment = 3;
|
|
SET SESSION auto_increment_offset = 1;
|
|
|
|
CREATE TABLE t1 (
|
|
i int(11) NOT NULL primary key AUTO_INCREMENT,
|
|
c char(32) DEFAULT 'dummy_text'
|
|
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
|
|
|
|
show variables like 'auto_increment%';
|
|
insert into t1(i) values(null);
|
|
|
|
select * from t1 order by i;
|
|
|
|
insert into t1(i) values(null), (null), (null);
|
|
|
|
select * from t1 order by i;
|
|
|
|
--connection node_2
|
|
--let $wait_condition = SELECT COUNT(*) = 4 FROM t1;
|
|
--source include/wait_condition.inc
|
|
show variables like 'auto_increment%';
|
|
|
|
select * from t1 order by i;
|
|
|
|
--connection node_1
|
|
SET GLOBAL wsrep_auto_increment_control='ON';
|
|
SET SESSION binlog_format='ROW';
|
|
--source include/auto_increment_offset_restore.inc
|
|
--connection node_1
|
|
show variables like 'binlog_format';
|
|
show variables like '%auto_increment%';
|
|
|
|
##
|
|
## Verify the recovery of original user-defined values after
|
|
## stopping the automatic control over auto-increment:
|
|
##
|
|
|
|
SET GLOBAL wsrep_auto_increment_control='OFF';
|
|
|
|
show variables like '%auto_increment%';
|
|
|
|
##
|
|
## Restore original options and drop test table:
|
|
##
|
|
|
|
SET GLOBAL wsrep_auto_increment_control='ON';
|
|
--source include/auto_increment_offset_restore.inc
|
|
--connection node_1
|
|
drop table t1;
|
|
|
|
##
|
|
## Verify the correct operation of the auto-increment when the binlog
|
|
## format set to the 'ROW':
|
|
##
|
|
|
|
--connection node_2
|
|
SET GLOBAL wsrep_forced_binlog_format='ROW';
|
|
|
|
--connection node_1
|
|
SET GLOBAL wsrep_forced_binlog_format='ROW';
|
|
|
|
CREATE TABLE t1 (
|
|
i int(11) NOT NULL primary key AUTO_INCREMENT,
|
|
c char(32) DEFAULT 'dummy_text'
|
|
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
|
|
|
|
show variables like 'auto_increment%';
|
|
insert into t1(i) values(null);
|
|
|
|
select * from t1 order by i;
|
|
|
|
insert into t1(i) values(null), (null), (null);
|
|
|
|
select * from t1 order by i;
|
|
|
|
--connection node_2
|
|
--let $wait_condition = SELECT COUNT(*) = 4 FROM t1;
|
|
--source include/wait_condition.inc
|
|
|
|
show variables like 'auto_increment%';
|
|
select * from t1 order by i;
|
|
|
|
SET GLOBAL wsrep_forced_binlog_format='none';
|
|
|
|
--connection node_1
|
|
|
|
SET GLOBAL wsrep_forced_binlog_format='none';
|
|
|
|
drop table t1;
|
|
|
|
##
|
|
## Check the operation when the automatic control over the auto-increment
|
|
## settings is switched off, that is, when we use the increment step and
|
|
## the offset specified by the user. In the current session, the binlog
|
|
## format is set to 'ROW'. It is important that the values of the
|
|
## auto-increment options does not changed on other node - it allows us
|
|
## to check the correct transmission of the auto-increment options to
|
|
## other nodes:
|
|
##
|
|
|
|
SET SESSION binlog_format='ROW';
|
|
|
|
show variables like 'binlog_format';
|
|
|
|
SET GLOBAL wsrep_auto_increment_control='OFF';
|
|
|
|
SET SESSION auto_increment_increment = 3;
|
|
SET SESSION auto_increment_offset = 1;
|
|
|
|
CREATE TABLE t1 (
|
|
i int(11) NOT NULL primary key AUTO_INCREMENT,
|
|
c char(32) DEFAULT 'dummy_text'
|
|
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
|
|
|
|
show variables like 'auto_increment%';
|
|
insert into t1(i) values(null);
|
|
|
|
select * from t1 order by i;
|
|
|
|
insert into t1(i) values(null), (null), (null);
|
|
|
|
select * from t1 order by i;
|
|
|
|
--connection node_2
|
|
--let $wait_condition = SELECT COUNT(*) = 4 FROM t1;
|
|
--source include/wait_condition.inc
|
|
show variables like 'auto_increment%';
|
|
|
|
select * from t1 order by i;
|
|
|
|
--connection node_1
|
|
|
|
##
|
|
## Verify the return to automatic calculation of the step
|
|
## and offset of the auto-increment:
|
|
##
|
|
|
|
SET GLOBAL wsrep_auto_increment_control='ON';
|
|
--source include/auto_increment_offset_restore.inc
|
|
|
|
show variables like 'binlog_format';
|
|
show variables like '%auto_increment%';
|
|
|
|
##
|
|
## Verify the recovery of original user-defined values after
|
|
## stopping the automatic control over auto-increment:
|
|
##
|
|
|
|
SET GLOBAL wsrep_auto_increment_control='OFF';
|
|
|
|
show variables like '%auto_increment%';
|
|
|
|
##
|
|
## Restore original options and drop test table:
|
|
##
|
|
|
|
SET GLOBAL wsrep_auto_increment_control='ON';
|
|
|
|
drop table t1;
|
|
|
|
--source include/auto_increment_offset_restore.inc
|