Commit 0c95fd23 authored by aelkin@mysql.com's avatar aelkin@mysql.com

Merge mysql.com:/usr_rh9/home/elkin.rh9/MySQL/Merge/tmp_merge

into  mysql.com:/usr_rh9/home/elkin.rh9/MySQL/Merge/5.1-new
parents a55b7a9f cf6becde
stop slave;
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
reset master;
reset slave;
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
start slave;
drop database if exists d1;
drop database if exists d2;
drop database if exists d2;
create database d1;
create table d1.t0 (id int);
create database d2;
use d2;
create table t1 (id int);
create table t2 (id int);
insert into t1 values (1), (2), (3), (4), (5);
insert into t2 select id + 3 from t1;
update t1 join t2 using (id) set t1.id = 0;
insert into d1.t0 values (0);
use d1;
select * from t0 where id=0;
id
0
drop database d1;
drop database d2;
--replicate-wild-do-table=d1.%
# Let's verify that multi-update is not always skipped by slave if
# some replicate-* rules exist.
# (BUG#15699)
source include/master-slave.inc;
### Clean-up
connection master;
--disable_warnings
drop database if exists d1;
drop database if exists d2;
connection slave;
drop database if exists d2;
--enable_warnings
### Test
connection master;
create database d1; # accepted by slave
create table d1.t0 (id int);
create database d2; # ignored by slave
use d2;
create table t1 (id int);
create table t2 (id int);
insert into t1 values (1), (2), (3), (4), (5);
insert into t2 select id + 3 from t1;
# a problematic query which must be filter out by slave
update t1 join t2 using (id) set t1.id = 0;
insert into d1.t0 values (0); # replication works
sync_slave_with_master;
use d1;
#connection slave;
select * from t0 where id=0; # must find
### Clean-up
connection master;
drop database d1;
drop database d2;
# End of test
...@@ -2419,23 +2419,26 @@ mysql_execute_command(THD *thd) ...@@ -2419,23 +2419,26 @@ mysql_execute_command(THD *thd)
} }
} }
else else
{
#endif /* HAVE_REPLICATION */ #endif /* HAVE_REPLICATION */
/*
/* When option readonly is set deny operations which change non-temporary
When option readonly is set deny operations which change non-temporary tables. Except for the replication thread and the 'super' users.
tables. Except for the replication thread and the 'super' users. */
*/ if (opt_readonly &&
if (opt_readonly && !(thd->security_ctx->master_access & SUPER_ACL) &&
!(thd->security_ctx->master_access & SUPER_ACL) && uc_update_queries[lex->sql_command] &&
uc_update_queries[lex->sql_command] && !((lex->sql_command == SQLCOM_CREATE_TABLE) &&
!((lex->sql_command == SQLCOM_CREATE_TABLE) && (lex->create_info.options & HA_LEX_CREATE_TMP_TABLE)) &&
(lex->create_info.options & HA_LEX_CREATE_TMP_TABLE)) && ((lex->sql_command != SQLCOM_UPDATE_MULTI) &&
((lex->sql_command != SQLCOM_UPDATE_MULTI) && some_non_temp_table_to_be_updated(thd, all_tables)))
some_non_temp_table_to_be_updated(thd, all_tables))) {
{ my_error(ER_OPTION_PREVENTS_STATEMENT, MYF(0), "--read-only");
my_error(ER_OPTION_PREVENTS_STATEMENT, MYF(0), "--read-only"); DBUG_RETURN(-1);
DBUG_RETURN(-1); }
} #ifdef HAVE_REPLICATION
} /* endif unlikely slave */
#endif
if(lex->orig_sql_command == SQLCOM_END) if(lex->orig_sql_command == SQLCOM_END)
statistic_increment(thd->status_var.com_stat[lex->sql_command], statistic_increment(thd->status_var.com_stat[lex->sql_command],
&LOCK_status); &LOCK_status);
...@@ -3231,8 +3234,7 @@ end_with_restore_list: ...@@ -3231,8 +3234,7 @@ end_with_restore_list:
else else
res= 0; res= 0;
if ((res= mysql_multi_update_prepare(thd))) res= mysql_multi_update_prepare(thd);
break;
#ifdef HAVE_REPLICATION #ifdef HAVE_REPLICATION
/* Check slave filtering rules */ /* Check slave filtering rules */
...@@ -3240,20 +3242,33 @@ end_with_restore_list: ...@@ -3240,20 +3242,33 @@ end_with_restore_list:
{ {
if (all_tables_not_ok(thd, all_tables)) if (all_tables_not_ok(thd, all_tables))
{ {
if (res!= 0)
{
res= 0; /* don't care of prev failure */
thd->clear_error(); /* filters are of highest prior */
}
/* we warn the slave SQL thread */ /* we warn the slave SQL thread */
my_error(ER_SLAVE_IGNORED_TABLE, MYF(0)); my_error(ER_SLAVE_IGNORED_TABLE, MYF(0));
break; break;
} }
if (res)
break;
} }
else else
#endif /* HAVE_REPLICATION */
if (opt_readonly &&
!(thd->security_ctx->master_access & SUPER_ACL) &&
some_non_temp_table_to_be_updated(thd, all_tables))
{ {
my_error(ER_OPTION_PREVENTS_STATEMENT, MYF(0), "--read-only"); #endif /* HAVE_REPLICATION */
break; if (res)
} break;
if (opt_readonly &&
!(thd->security_ctx->master_access & SUPER_ACL) &&
some_non_temp_table_to_be_updated(thd, all_tables))
{
my_error(ER_OPTION_PREVENTS_STATEMENT, MYF(0), "--read-only");
break;
}
#ifdef HAVE_REPLICATION
} /* unlikely */
#endif
res= mysql_multi_update(thd, all_tables, res= mysql_multi_update(thd, all_tables,
&select_lex->item_list, &select_lex->item_list,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment