polardbxengine/mysql-test/suite/rpl/r/rpl_auto_increment_innodb.r...

135 lines
3.1 KiB
Plaintext

include/master-slave.inc
Warnings:
Note #### Sending passwords in plain text without SSL/TLS is extremely insecure.
Note #### Storing MySQL user name or password information in the master info repository is not secure and is therefore not recommended. Please consider using the USER and PASSWORD connection options for START SLAVE; see the 'START SLAVE Syntax' in the MySQL Manual for more information.
[connection master]
create table t1 (a int not null auto_increment, primary key (a)) engine=innodb;
insert into t1 values (NULL),(5),(NULL);
insert into t1 values (250),(NULL);
select * from t1;
a
1
5
6
250
251
insert into t1 values (1000);
set @@insert_id=400;
insert into t1 values(NULL),(NULL);
select * from t1;
a
1
5
6
250
251
400
401
1000
include/sync_slave_sql_with_master.inc
select * from t1;
a
1
5
6
250
251
400
401
1000
drop table t1;
set auto_increment_increment=1;
set auto_increment_offset=1;
CREATE TABLE t1 (id MEDIUMINT NOT NULL AUTO_INCREMENT PRIMARY KEY) ENGINE=innodb;
INSERT INTO t1 VALUES (NULL), (NULL), (NULL);
show create table t1;
Table Create Table
t1 CREATE TABLE `t1` (
`id` mediumint(9) NOT NULL AUTO_INCREMENT,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
include/sync_slave_sql_with_master.inc
show create table t1;
Table Create Table
t1 CREATE TABLE `t1` (
`id` mediumint(9) NOT NULL AUTO_INCREMENT,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
drop table t1;
include/rpl_reset.inc
DROP TABLE IF EXISTS t1;
CREATE TABLE t1 (id INT NOT NULL AUTO_INCREMENT PRIMARY KEY) ENGINE=innodb;
SET SQL_MODE='';
INSERT INTO t1 VALUES(NULL);
SELECT * FROM t1;
id
1
INSERT INTO t1 VALUES();
SELECT * FROM t1;
id
1
2
INSERT INTO t1 VALUES(0);
SELECT * FROM t1;
id
1
2
3
SET SQL_MODE=NO_AUTO_VALUE_ON_ZERO;
INSERT INTO t1 VALUES(0);
SELECT * FROM t1;
id
0
1
2
3
INSERT INTO t1 VALUES(4);
FLUSH LOGS;
include/sync_slave_sql_with_master.inc
include/diff_tables.inc [master:t1, slave:t1]
DROP TABLE t1;
include/sync_slave_sql_with_master.inc
include/stop_slave.inc
RESET SLAVE;
RESET MASTER;
RESET MASTER;
FLUSH LOGS;
include/start_slave.inc
include/sync_slave_sql_with_master.inc
include/diff_tables.inc [master:t1, slave:t1]
DROP TABLE t1;
SET SQL_MODE='';
include/sync_slave_sql_with_master.inc
CREATE TABLE t1 (id SMALLINT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY, data INT) ENGINE=innodb;
BEGIN;
# Set sql_mode with NO_AUTO_VALUE_ON_ZERO for allowing
# zero to fill the auto_increment field.
SET SQL_MODE=NO_AUTO_VALUE_ON_ZERO;
INSERT INTO t1(id,data) VALUES(0,2);
# Resetting sql_mode without NO_AUTO_VALUE_ON_ZERO to
# affect the execution of the transaction on slave.
SET SQL_MODE=0;
COMMIT;
SELECT * FROM t1;
id data
0 2
include/sync_slave_sql_with_master.inc
SELECT * FROM t1;
id data
0 2
DROP TABLE t1;
include/sync_slave_sql_with_master.inc
create table t1(a int auto_increment primary key) engine=innodb;
insert into t1 values (null),(null),(1025),(null);
include/sync_slave_sql_with_master.inc
select * from t1;
a
1
2
1025
1026
include/diff_tables.inc [master:t1, slave:t1]
drop table t1;
include/sync_slave_sql_with_master.inc
include/rpl_end.inc