Skip to content

Commit

Permalink
MDEV-29069 follow-up: support partially usable keys
Browse files Browse the repository at this point in the history
  • Loading branch information
FooBarrior authored and vuvova committed Aug 15, 2023
1 parent bac728a commit 3075677
Show file tree
Hide file tree
Showing 7 changed files with 336 additions and 24 deletions.
4 changes: 2 additions & 2 deletions mysql-test/main/alter_table_online_debug.result
Expand Up @@ -1054,8 +1054,8 @@ update t set a = a + 1 where a = 10;
set debug_sync= 'now signal goforit';
connection default;
Warnings:
Note 1105 Key chosen: -1
Note 1105 Key chosen: -1
Note 1105 Key chosen: 0
Note 1105 Key chosen: 0
select a from t;
a
11
Expand Down
145 changes: 145 additions & 0 deletions mysql-test/suite/rpl/r/rpl_alter_extra_persistent.result
Expand Up @@ -216,4 +216,149 @@ a
6
7
drop table t1;
connection slave;
connection master;
set binlog_row_image=minimal;
create table t1(a int primary key auto_increment, b int unique);
insert into t1 values(1, 1);
insert into t1 values(2, 2);
insert into t1 values(3, 3);
insert into t1 values(4, 4);
insert into t1 values(5, 5);
connection slave;
alter table t1 add column d1 int default (b),
add column z1 int as (b+1) virtual,
add column z2 int as (b+2) persistent;
connection master;
insert into t1 values(6, 6);
update t1 set a = 11 where a = 1;
update t1 set b = 12 where b = 2;
delete from t1 where a = 3;
delete from t1 where b = 5;
update t1 set b = 16 where a = 6;
connection slave;
select * from t1;
a b d1 z1 z2
11 1 1 2 3
2 12 2 13 14
4 4 4 5 6
6 16 6 17 18
# Cleanup
connection master;
drop table t1;
connection slave;
connection master;
set binlog_row_image=minimal;
#
# MDEV-29069 ER_KEY_NOT_FOUND upon online autoinc addition and
# concurrent DELETE
#
create or replace table t (a int);
insert into t values (10),(20),(30);
connection slave;
alter table t add pk int auto_increment primary key;
connection master;
delete from t where a = 20;
update t set a = a + 1 where a = 10;
connection slave;
select * from t;
a pk
11 1
30 3
connection master;
#
# Add clumsy DEFAULT
#
create or replace table t (a int);
insert into t values (10),(20),(30);
connection slave;
alter table t add b int default(RAND() * 20), add key(b),
algorithm=copy, lock=none;
connection master;
delete from t where a = 20;
update t set a = a + 1 where a = 10;
connection slave;
select a from t;
a
11
30
connection master;
# CURRENT_TIMESTAMP
create or replace table t (a int);
insert into t values (10),(20),(30);
connection slave;
alter table t add b timestamp default CURRENT_TIMESTAMP, add key(b);
connection master;
delete from t where a = 20;
update t set a = a + 1 where a = 10;
connection slave;
select a from t;
a
11
30
connection master;
# CURRENT_TIMESTAMP, mixed key
create or replace table t (a int);
insert into t values (10),(20),(30);
connection slave;
alter table t add b timestamp default CURRENT_TIMESTAMP, add key(a, b);
connection master;
delete from t where a = 20;
update t set a = a + 1 where a = 10;
connection slave;
select a from t;
a
11
30
connection master;
# Mixed primary key
create or replace table t (a int);
insert into t values (10),(20),(30);
connection slave;
alter table t add b int default (1), add primary key(b, a);
connection master;
delete from t where a = 20;
update t set a = a + 1 where a = 10;
connection slave;
select a from t;
a
11
30
connection master;
#
# Normal row, could be used as a key
#
create or replace table t (a int);
insert into t values (10),(20),(30);
connection slave;
alter table t add b int as (a * 10) unique;
connection master;
delete from t where a = 20;
update t set a = a + 1 where a = 10;
connection slave;
select * from t;
a b
11 110
30 300
connection master;
#
# Add key for old row
#
create or replace table t (a int);
insert into t values (10),(20),(30);
connection slave;
alter table t add unique(a);
connection master;
delete from t where a = 20;
update t set a = a + 1 where a = 10;
connection slave;
select * from t;
a
11
30
# Cleanup
connection master;
connection slave;
connection master;
drop table t;
include/rpl_end.inc
152 changes: 151 additions & 1 deletion mysql-test/suite/rpl/t/rpl_alter_extra_persistent.test
Expand Up @@ -103,12 +103,162 @@ start slave;

--source include/wait_for_slave_sql_to_start.inc

--connection master
--connection master
--sync_slave_with_master
select * from t1 order by a;

--connection master
select * from t1 order by a;
drop table t1;
--sync_slave_with_master
--connection master

set binlog_row_image=minimal;

create table t1(a int primary key auto_increment, b int unique);
insert into t1 values(1, 1);
insert into t1 values(2, 2);
insert into t1 values(3, 3);
insert into t1 values(4, 4);
insert into t1 values(5, 5);

--sync_slave_with_master
alter table t1 add column d1 int default (b),
add column z1 int as (b+1) virtual,
add column z2 int as (b+2) persistent;
--connection master

insert into t1 values(6, 6);
update t1 set a = 11 where a = 1;
update t1 set b = 12 where b = 2;

delete from t1 where a = 3;
delete from t1 where b = 5;

update t1 set b = 16 where a = 6;

--sync_slave_with_master
select * from t1;

--echo # Cleanup
--connection master
drop table t1;
--sync_slave_with_master
--connection master


set binlog_row_image=minimal;

--echo #
--echo # MDEV-29069 ER_KEY_NOT_FOUND upon online autoinc addition and
--echo # concurrent DELETE
--echo #

create or replace table t (a int);
insert into t values (10),(20),(30);

--sync_slave_with_master
alter table t add pk int auto_increment primary key;

--connection master
delete from t where a = 20;
update t set a = a + 1 where a = 10;
--sync_slave_with_master
select * from t;
--connection master

--echo #
--echo # Add clumsy DEFAULT
--echo #
create or replace table t (a int);
insert into t values (10),(20),(30);

--sync_slave_with_master
alter table t add b int default(RAND() * 20), add key(b),
algorithm=copy, lock=none;
--connection master
delete from t where a = 20;
update t set a = a + 1 where a = 10;
--sync_slave_with_master
select a from t;
--connection master

--echo # CURRENT_TIMESTAMP
create or replace table t (a int);
insert into t values (10),(20),(30);

--sync_slave_with_master
alter table t add b timestamp default CURRENT_TIMESTAMP, add key(b);
--connection master
delete from t where a = 20;
update t set a = a + 1 where a = 10;
--sync_slave_with_master
select a from t;
--connection master

--echo # CURRENT_TIMESTAMP, mixed key
create or replace table t (a int);
insert into t values (10),(20),(30);

--sync_slave_with_master
alter table t add b timestamp default CURRENT_TIMESTAMP, add key(a, b);
--connection master
delete from t where a = 20;
update t set a = a + 1 where a = 10;

--sync_slave_with_master
select a from t;
--connection master

--echo # Mixed primary key
create or replace table t (a int);
insert into t values (10),(20),(30);

--sync_slave_with_master
alter table t add b int default (1), add primary key(b, a);
--connection master
delete from t where a = 20;
update t set a = a + 1 where a = 10;

--sync_slave_with_master
select a from t;
--connection master

--echo #
--echo # Normal row, could be used as a key
--echo #
create or replace table t (a int);
insert into t values (10),(20),(30);

--sync_slave_with_master
alter table t add b int as (a * 10) unique;
--connection master
delete from t where a = 20;
update t set a = a + 1 where a = 10;

--sync_slave_with_master
select * from t;
--connection master

--echo #
--echo # Add key for old row
--echo #
create or replace table t (a int);
insert into t values (10),(20),(30);

--sync_slave_with_master
alter table t add unique(a);
--connection master
delete from t where a = 20;
update t set a = a + 1 where a = 10;

--sync_slave_with_master
select * from t;

--echo # Cleanup
--connection master
--sync_slave_with_master
--connection master
drop table t;

--source include/rpl_end.inc
2 changes: 1 addition & 1 deletion sql/log_event.cc
Expand Up @@ -2965,7 +2965,7 @@ Rows_log_event::Rows_log_event(const uchar *buf, uint event_len,
#if !defined(MYSQL_CLIENT) && defined(HAVE_REPLICATION)
, m_curr_row(NULL), m_curr_row_end(NULL),
m_key(NULL), m_key_info(NULL), m_key_nr(0),
master_had_triggers(0)
m_usable_key_parts(0), master_had_triggers(0)
#endif
{
DBUG_ENTER("Rows_log_event::Rows_log_event(const char*,...)");
Expand Down
3 changes: 2 additions & 1 deletion sql/log_event.h
Expand Up @@ -4751,6 +4751,7 @@ class Rows_log_event : public Log_event
uchar *m_key; /* Buffer to keep key value during searches */
KEY *m_key_info; /* Pointer to KEY info for m_key_nr */
uint m_key_nr; /* Key number */
uint m_usable_key_parts; /* A number of key_parts suited to lookup */
bool master_had_triggers; /* set after tables opening */

/*
Expand Down Expand Up @@ -4799,7 +4800,7 @@ class Rows_log_event : public Log_event
};

int find_key(const rpl_group_info *); // Find a best key to use in find_row()
bool is_key_usable(const KEY *key) const;
uint find_key_parts(const KEY *key) const;
bool use_pk_position() const;
int find_row(rpl_group_info *);
int write_row(rpl_group_info *, const bool);
Expand Down

0 comments on commit 3075677

Please sign in to comment.