mirror of
https://github.com/MariaDB/server.git
synced 2025-11-19 19:03:26 +03:00
Merge jmiller@bk-internal.mysql.com:/home/bk/mysql-5.1-new
into mysql.com:/home/ndbdev/jmiller/clones/mysql-5.1-new
This commit is contained in:
@@ -57,8 +57,8 @@ TABLES
|
||||
TABLE_CONSTRAINTS
|
||||
TABLE_PRIVILEGES
|
||||
TRIGGERS
|
||||
VIEWS
|
||||
USER_PRIVILEGES
|
||||
VIEWS
|
||||
binlog_index
|
||||
columns_priv
|
||||
db
|
||||
|
||||
@@ -20,8 +20,8 @@ TABLES
|
||||
TABLE_CONSTRAINTS
|
||||
TABLE_PRIVILEGES
|
||||
TRIGGERS
|
||||
VIEWS
|
||||
USER_PRIVILEGES
|
||||
VIEWS
|
||||
show tables from INFORMATION_SCHEMA like 'T%';
|
||||
Tables_in_information_schema (T%)
|
||||
TABLES
|
||||
|
||||
@@ -1481,3 +1481,26 @@ id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t2 ref a a 5 test.t1.a 1
|
||||
1 SIMPLE t3 ref a a 5 test.t2.a 1
|
||||
drop table t1, t2, t3;
|
||||
CREATE TABLE t1 (id int NOT NULL PRIMARY KEY, type varchar(10));
|
||||
CREATE TABLE t2 (pid int NOT NULL PRIMARY KEY, type varchar(10));
|
||||
CREATE TABLE t3 (cid int NOT NULL PRIMARY KEY,
|
||||
id int NOT NULL,
|
||||
pid int NOT NULL);
|
||||
INSERT INTO t1 VALUES (1, 'A'), (3, 'C');
|
||||
INSERT INTO t2 VALUES (1, 'A'), (3, 'C');
|
||||
INSERT INTO t3 VALUES (1, 1, 1), (3, 3, 3);
|
||||
SELECT * FROM t1 p LEFT JOIN (t3 JOIN t1)
|
||||
ON (t1.id=t3.id AND t1.type='B' AND p.id=t3.id)
|
||||
LEFT JOIN t2 ON (t3.pid=t2.pid)
|
||||
WHERE p.id=1;
|
||||
id type cid id pid id type pid type
|
||||
1 A NULL NULL NULL NULL NULL NULL NULL
|
||||
CREATE VIEW v1 AS
|
||||
SELECT t3.* FROM t3 JOIN t1 ON t1.id=t3.id AND t1.type='B';
|
||||
SELECT * FROM t1 p LEFT JOIN v1 ON p.id=v1.id
|
||||
LEFT JOIN t2 ON v1.pid=t2.pid
|
||||
WHERE p.id=1;
|
||||
id type cid id pid pid type
|
||||
1 A NULL NULL NULL NULL NULL
|
||||
DROP VIEW v1;
|
||||
DROP TABLE t1,t2,t3;
|
||||
|
||||
16
mysql-test/r/rpl_ignore_table.result
Normal file
16
mysql-test/r/rpl_ignore_table.result
Normal file
@@ -0,0 +1,16 @@
|
||||
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;
|
||||
**** Test case for BUG#16487 ****
|
||||
**** Master ****
|
||||
CREATE TABLE test.t4 (a int);
|
||||
CREATE TABLE test.t1 (a int);
|
||||
UPDATE test.t4 NATURAL JOIN test.t1 SET t1.a=5;
|
||||
**** Slave ****
|
||||
SELECT * FROM t4;
|
||||
a
|
||||
DROP TABLE t1;
|
||||
DROP TABLE t4;
|
||||
@@ -914,3 +914,31 @@ explain select * from t1 left join
|
||||
on (t1.a = t2.a);
|
||||
drop table t1, t2, t3;
|
||||
|
||||
#
|
||||
# Bug #16260: single row table in the inner nest of an outer join
|
||||
#
|
||||
|
||||
CREATE TABLE t1 (id int NOT NULL PRIMARY KEY, type varchar(10));
|
||||
CREATE TABLE t2 (pid int NOT NULL PRIMARY KEY, type varchar(10));
|
||||
CREATE TABLE t3 (cid int NOT NULL PRIMARY KEY,
|
||||
id int NOT NULL,
|
||||
pid int NOT NULL);
|
||||
|
||||
INSERT INTO t1 VALUES (1, 'A'), (3, 'C');
|
||||
INSERT INTO t2 VALUES (1, 'A'), (3, 'C');
|
||||
INSERT INTO t3 VALUES (1, 1, 1), (3, 3, 3);
|
||||
|
||||
SELECT * FROM t1 p LEFT JOIN (t3 JOIN t1)
|
||||
ON (t1.id=t3.id AND t1.type='B' AND p.id=t3.id)
|
||||
LEFT JOIN t2 ON (t3.pid=t2.pid)
|
||||
WHERE p.id=1;
|
||||
|
||||
CREATE VIEW v1 AS
|
||||
SELECT t3.* FROM t3 JOIN t1 ON t1.id=t3.id AND t1.type='B';
|
||||
|
||||
SELECT * FROM t1 p LEFT JOIN v1 ON p.id=v1.id
|
||||
LEFT JOIN t2 ON v1.pid=t2.pid
|
||||
WHERE p.id=1;
|
||||
|
||||
DROP VIEW v1;
|
||||
DROP TABLE t1,t2,t3;
|
||||
|
||||
1
mysql-test/t/rpl_ignore_table-slave.opt
Normal file
1
mysql-test/t/rpl_ignore_table-slave.opt
Normal file
@@ -0,0 +1 @@
|
||||
--replicate-ignore-table=test.t1 --replicate-ignore-table=test.t2 --replicate-ignore-table=test.t3
|
||||
28
mysql-test/t/rpl_ignore_table.test
Normal file
28
mysql-test/t/rpl_ignore_table.test
Normal file
@@ -0,0 +1,28 @@
|
||||
source include/master-slave.inc;
|
||||
|
||||
#
|
||||
# BUG#16487
|
||||
#
|
||||
# Requirement:
|
||||
# Multi-updates on ignored tables should not fail even if the slave does
|
||||
# not have the ignored tables.
|
||||
#
|
||||
# Note table t1, t2, and t3 are ignored in the option file to this test.
|
||||
#
|
||||
|
||||
--echo **** Test case for BUG#16487 ****
|
||||
--echo **** Master ****
|
||||
connection master;
|
||||
CREATE TABLE test.t4 (a int);
|
||||
CREATE TABLE test.t1 (a int);
|
||||
|
||||
# Expect: The row must *not* by updated on slave, since t1 is ignored
|
||||
UPDATE test.t4 NATURAL JOIN test.t1 SET t1.a=5;
|
||||
|
||||
--echo **** Slave ****
|
||||
sync_slave_with_master;
|
||||
SELECT * FROM t4;
|
||||
|
||||
connection master;
|
||||
DROP TABLE t1;
|
||||
DROP TABLE t4;
|
||||
Reference in New Issue
Block a user