mirror of
https://github.com/MariaDB/server.git
synced 2025-07-29 05:21:33 +03:00
Merge joreland@bk-internal.mysql.com:/home/bk/mysql-5.0
into mysql.com:/home/jonas/src/mysql-5.0
This commit is contained in:
@ -47,3 +47,13 @@ unlock tables;
|
||||
lock tables t1 write, t1 as t1_alias read;
|
||||
insert into t1 select index1,nr from t1 as t1_alias;
|
||||
drop table t1,t2;
|
||||
create table t1 ( a int(11) not null auto_increment, primary key(a));
|
||||
create table t2 ( a int(11) not null auto_increment, primary key(a));
|
||||
lock tables t1 write, t2 read;
|
||||
delete from t1 using t1,t2 where t1.a=t2.a;
|
||||
delete t1 from t1,t2 where t1.a=t2.a;
|
||||
delete from t2 using t1,t2 where t1.a=t2.a;
|
||||
ERROR HY000: Table 't2' was locked with a READ lock and can't be updated
|
||||
delete t2 from t1,t2 where t1.a=t2.a;
|
||||
ERROR HY000: Table 't2' was locked with a READ lock and can't be updated
|
||||
drop table t1,t2;
|
||||
|
@ -68,14 +68,18 @@ master-bin.000002 260 Query 1 346 use `test`; create table t1 (n int)
|
||||
master-bin.000002 346 Query 1 434 use `test`; insert into t1 values (1)
|
||||
master-bin.000002 434 Query 1 510 use `test`; drop table t1
|
||||
show binary logs;
|
||||
Log_name
|
||||
master-bin.000001
|
||||
master-bin.000002
|
||||
Log_name File_size
|
||||
master-bin.000001 0
|
||||
master-bin.000002 510
|
||||
Warnings:
|
||||
Error 29 File 'master-bin.000001' not found (Errcode: 2)
|
||||
start slave;
|
||||
show binary logs;
|
||||
Log_name
|
||||
slave-bin.000001
|
||||
slave-bin.000002
|
||||
Log_name File_size
|
||||
slave-bin.000001 0
|
||||
slave-bin.000002 348
|
||||
Warnings:
|
||||
Error 29 File 'slave-bin.000001' not found (Errcode: 2)
|
||||
show binlog events in 'slave-bin.000001' from 4;
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
slave-bin.000001 4 Format_desc 2 98 Server ver: VERSION, Binlog ver: 4
|
||||
|
@ -26,10 +26,13 @@ create table t2(m int not null auto_increment primary key);
|
||||
insert into t2 values (34),(67),(123);
|
||||
flush logs;
|
||||
show binary logs;
|
||||
Log_name
|
||||
master-bin.000001
|
||||
master-bin.000002
|
||||
master-bin.000003
|
||||
Log_name File_size
|
||||
master-bin.000001 0
|
||||
master-bin.000002 0
|
||||
master-bin.000003 98
|
||||
Warnings:
|
||||
Error 29 File 'master-bin.000001' not found (Errcode: 2)
|
||||
Error 29 File 'master-bin.000002' not found (Errcode: 2)
|
||||
create table t3 select * from temp_table;
|
||||
select * from t3;
|
||||
a
|
||||
@ -42,18 +45,22 @@ set global sql_slave_skip_counter=1;
|
||||
start slave;
|
||||
purge master logs to 'master-bin.000002';
|
||||
show master logs;
|
||||
Log_name
|
||||
master-bin.000002
|
||||
master-bin.000003
|
||||
Log_name File_size
|
||||
master-bin.000002 0
|
||||
master-bin.000003 407
|
||||
Warnings:
|
||||
Error 29 File 'master-bin.000002' not found (Errcode: 2)
|
||||
purge binary logs to 'master-bin.000002';
|
||||
show binary logs;
|
||||
Log_name
|
||||
master-bin.000002
|
||||
master-bin.000003
|
||||
Log_name File_size
|
||||
master-bin.000002 0
|
||||
master-bin.000003 407
|
||||
Warnings:
|
||||
Error 29 File 'master-bin.000002' not found (Errcode: 2)
|
||||
purge master logs before now();
|
||||
show binary logs;
|
||||
Log_name
|
||||
master-bin.000003
|
||||
Log_name File_size
|
||||
master-bin.000003 407
|
||||
insert into t2 values (65);
|
||||
show slave status;
|
||||
Slave_IO_State Master_Host Master_User Master_Port Connect_Retry Master_Log_File Read_Master_Log_Pos Relay_Log_File Relay_Log_Pos Relay_Master_Log_File Slave_IO_Running Slave_SQL_Running Replicate_Do_DB Replicate_Ignore_DB Replicate_Do_Table Replicate_Ignore_Table Replicate_Wild_Do_Table Replicate_Wild_Ignore_Table Last_Errno Last_Error Skip_Counter Exec_Master_Log_Pos Relay_Log_Space Until_Condition Until_Log_File Until_Log_Pos Master_SSL_Allowed Master_SSL_CA_File Master_SSL_CA_Path Master_SSL_Cert Master_SSL_Cipher Master_SSL_Key Seconds_Behind_Master
|
||||
@ -73,10 +80,13 @@ count(*)
|
||||
100
|
||||
create table t4 select * from temp_table;
|
||||
show binary logs;
|
||||
Log_name
|
||||
master-bin.000003
|
||||
master-bin.000004
|
||||
master-bin.000005
|
||||
Log_name File_size
|
||||
master-bin.000003 0
|
||||
master-bin.000004 0
|
||||
master-bin.000005 2032
|
||||
Warnings:
|
||||
Error 29 File 'master-bin.000003' not found (Errcode: 2)
|
||||
Error 29 File 'master-bin.000004' not found (Errcode: 2)
|
||||
show master status;
|
||||
File Position Binlog_Do_DB Binlog_Ignore_DB
|
||||
master-bin.000005 2032
|
||||
|
@ -140,6 +140,48 @@ drop trigger t1.trg1;
|
||||
drop trigger t1.trg2;
|
||||
drop trigger t1.trg3;
|
||||
drop table t1;
|
||||
create table t1 (id int not null primary key, data int);
|
||||
create trigger t1_bi before insert on t1 for each row
|
||||
set @log:= concat(@log, "(BEFORE_INSERT: new=(id=", new.id, ", data=", new.data,"))");
|
||||
create trigger t1_ai after insert on t1 for each row
|
||||
set @log:= concat(@log, "(AFTER_INSERT: new=(id=", new.id, ", data=", new.data,"))");
|
||||
create trigger t1_bu before update on t1 for each row
|
||||
set @log:= concat(@log, "(BEFORE_UPDATE: old=(id=", old.id, ", data=", old.data,
|
||||
") new=(id=", new.id, ", data=", new.data,"))");
|
||||
create trigger t1_au after update on t1 for each row
|
||||
set @log:= concat(@log, "(AFTER_UPDATE: old=(id=", old.id, ", data=", old.data,
|
||||
") new=(id=", new.id, ", data=", new.data,"))");
|
||||
create trigger t1_bd before delete on t1 for each row
|
||||
set @log:= concat(@log, "(BEFORE_DELETE: old=(id=", old.id, ", data=", old.data,"))");
|
||||
create trigger t1_ad after delete on t1 for each row
|
||||
set @log:= concat(@log, "(AFTER_DELETE: old=(id=", old.id, ", data=", old.data,"))");
|
||||
set @log:= "";
|
||||
insert into t1 values (1, 1);
|
||||
select @log;
|
||||
@log
|
||||
(BEFORE_INSERT: new=(id=1, data=1))(AFTER_INSERT: new=(id=1, data=1))
|
||||
set @log:= "";
|
||||
insert ignore t1 values (1, 2);
|
||||
select @log;
|
||||
@log
|
||||
(BEFORE_INSERT: new=(id=1, data=2))
|
||||
set @log:= "";
|
||||
replace t1 values (1, 3), (2, 2);
|
||||
select @log;
|
||||
@log
|
||||
(BEFORE_INSERT: new=(id=1, data=3))(BEFORE_UPDATE: old=(id=1, data=1) new=(id=1, data=3))(AFTER_UPDATE: old=(id=1, data=1) new=(id=1, data=3))(BEFORE_INSERT: new=(id=2, data=2))(AFTER_INSERT: new=(id=2, data=2))
|
||||
alter table t1 add ts timestamp default now();
|
||||
set @log:= "";
|
||||
replace t1 (id, data) values (1, 4);
|
||||
select @log;
|
||||
@log
|
||||
(BEFORE_INSERT: new=(id=1, data=4))(BEFORE_DELETE: old=(id=1, data=3))(AFTER_DELETE: old=(id=1, data=3))(AFTER_INSERT: new=(id=1, data=4))
|
||||
set @log:= "";
|
||||
insert into t1 (id, data) values (1, 5), (3, 3) on duplicate key update data= data + 2;
|
||||
select @log;
|
||||
@log
|
||||
(BEFORE_INSERT: new=(id=1, data=5))(BEFORE_UPDATE: old=(id=1, data=4) new=(id=1, data=6))(AFTER_UPDATE: old=(id=1, data=4) new=(id=1, data=6))(BEFORE_INSERT: new=(id=3, data=3))(AFTER_INSERT: new=(id=3, data=3))
|
||||
drop table t1;
|
||||
create table t1 (i int);
|
||||
create trigger trg before insert on t1 for each row set @a:= old.i;
|
||||
ERROR HY000: There is no OLD row in on INSERT trigger
|
||||
@ -206,3 +248,70 @@ create table t1 (i int);
|
||||
create trigger trg1 before insert on t1 for each row set @a:= 1;
|
||||
drop database mysqltest;
|
||||
use test;
|
||||
create table t1 (i int, j int default 10, k int not null, key (k));
|
||||
create table t2 (i int);
|
||||
insert into t1 (i, k) values (1, 1);
|
||||
insert into t2 values (1);
|
||||
create trigger trg1 before update on t1 for each row set @a:= @a + new.j - old.j;
|
||||
create trigger trg2 after update on t1 for each row set @b:= "Fired";
|
||||
set @a:= 0, @b:= "";
|
||||
update t1, t2 set j = j + 10 where t1.i = t2.i;
|
||||
select @a, @b;
|
||||
@a @b
|
||||
10 Fired
|
||||
insert into t1 values (2, 13, 2);
|
||||
insert into t2 values (2);
|
||||
set @a:= 0, @b:= "";
|
||||
update t1, t2 set j = j + 15 where t1.i = t2.i and t1.k >= 2;
|
||||
select @a, @b;
|
||||
@a @b
|
||||
15 Fired
|
||||
create trigger trg3 before delete on t1 for each row set @c:= @c + old.j;
|
||||
create trigger trg4 before delete on t2 for each row set @d:= @d + old.i;
|
||||
create trigger trg5 after delete on t1 for each row set @e:= "After delete t1 fired";
|
||||
create trigger trg6 after delete on t2 for each row set @f:= "After delete t2 fired";
|
||||
set @c:= 0, @d:= 0, @e:= "", @f:= "";
|
||||
delete t1, t2 from t1, t2 where t1.i = t2.i;
|
||||
select @c, @d, @e, @f;
|
||||
@c @d @e @f
|
||||
48 3 After delete t1 fired After delete t2 fired
|
||||
drop table t1, t2;
|
||||
create table t1 (i int, j int default 10)|
|
||||
create table t2 (i int)|
|
||||
insert into t2 values (1), (2)|
|
||||
create trigger trg1 before insert on t1 for each row
|
||||
begin
|
||||
if new.i = 1 then
|
||||
set new.j := 1;
|
||||
end if;
|
||||
end|
|
||||
create trigger trg2 after insert on t1 for each row set @a:= 1|
|
||||
set @a:= 0|
|
||||
insert into t1 (i) select * from t2|
|
||||
select * from t1|
|
||||
i j
|
||||
1 1
|
||||
2 10
|
||||
select @a|
|
||||
@a
|
||||
1
|
||||
drop table t1, t2|
|
||||
create table t1 (i int, j int, k int);
|
||||
create trigger trg1 before insert on t1 for each row set new.k = new.i;
|
||||
create trigger trg2 after insert on t1 for each row set @b:= "Fired";
|
||||
set @b:="";
|
||||
load data infile '../../std_data/rpl_loaddata.dat' into table t1 (@a, i);
|
||||
select *, @b from t1;
|
||||
i j k @b
|
||||
10 NULL 10 Fired
|
||||
15 NULL 15 Fired
|
||||
set @b:="";
|
||||
load data infile '../../std_data/loaddata5.dat' into table t1 fields terminated by '' enclosed by '' (i, j);
|
||||
select *, @b from t1;
|
||||
i j k @b
|
||||
10 NULL 10 Fired
|
||||
15 NULL 15 Fired
|
||||
1 2 1 Fired
|
||||
3 4 3 Fired
|
||||
5 6 5 Fired
|
||||
drop table t1;
|
||||
|
@ -59,3 +59,17 @@ unlock tables;
|
||||
lock tables t1 write, t1 as t1_alias read;
|
||||
insert into t1 select index1,nr from t1 as t1_alias;
|
||||
drop table t1,t2;
|
||||
|
||||
#
|
||||
# Bug7241 - Invalid response when DELETE .. USING and LOCK TABLES used.
|
||||
#
|
||||
create table t1 ( a int(11) not null auto_increment, primary key(a));
|
||||
create table t2 ( a int(11) not null auto_increment, primary key(a));
|
||||
lock tables t1 write, t2 read;
|
||||
delete from t1 using t1,t2 where t1.a=t2.a;
|
||||
delete t1 from t1,t2 where t1.a=t2.a;
|
||||
--error 1099
|
||||
delete from t2 using t1,t2 where t1.a=t2.a;
|
||||
--error 1099
|
||||
delete t2 from t1,t2 where t1.a=t2.a;
|
||||
drop table t1,t2;
|
||||
|
@ -150,6 +150,55 @@ drop trigger t1.trg3;
|
||||
drop table t1;
|
||||
|
||||
|
||||
# Let us test how triggers work for special forms of INSERT such as
|
||||
# REPLACE and INSERT ... ON DUPLICATE KEY UPDATE
|
||||
create table t1 (id int not null primary key, data int);
|
||||
create trigger t1_bi before insert on t1 for each row
|
||||
set @log:= concat(@log, "(BEFORE_INSERT: new=(id=", new.id, ", data=", new.data,"))");
|
||||
create trigger t1_ai after insert on t1 for each row
|
||||
set @log:= concat(@log, "(AFTER_INSERT: new=(id=", new.id, ", data=", new.data,"))");
|
||||
create trigger t1_bu before update on t1 for each row
|
||||
set @log:= concat(@log, "(BEFORE_UPDATE: old=(id=", old.id, ", data=", old.data,
|
||||
") new=(id=", new.id, ", data=", new.data,"))");
|
||||
create trigger t1_au after update on t1 for each row
|
||||
set @log:= concat(@log, "(AFTER_UPDATE: old=(id=", old.id, ", data=", old.data,
|
||||
") new=(id=", new.id, ", data=", new.data,"))");
|
||||
create trigger t1_bd before delete on t1 for each row
|
||||
set @log:= concat(@log, "(BEFORE_DELETE: old=(id=", old.id, ", data=", old.data,"))");
|
||||
create trigger t1_ad after delete on t1 for each row
|
||||
set @log:= concat(@log, "(AFTER_DELETE: old=(id=", old.id, ", data=", old.data,"))");
|
||||
# Simple INSERT - both triggers should be called
|
||||
set @log:= "";
|
||||
insert into t1 values (1, 1);
|
||||
select @log;
|
||||
# INSERT IGNORE for already existing key - only before trigger should fire
|
||||
set @log:= "";
|
||||
insert ignore t1 values (1, 2);
|
||||
select @log;
|
||||
# REPLACE: before insert trigger should be called for both records,
|
||||
# but then for first one update will be executed (and both update
|
||||
# triggers should fire). For second after insert trigger will be
|
||||
# called as for usual insert
|
||||
set @log:= "";
|
||||
replace t1 values (1, 3), (2, 2);
|
||||
select @log;
|
||||
# Now let us change table in such way that REPLACE on won't be executed
|
||||
# using update.
|
||||
alter table t1 add ts timestamp default now();
|
||||
set @log:= "";
|
||||
# This REPLACE should be executed via DELETE and INSERT so proper
|
||||
# triggers should be invoked.
|
||||
replace t1 (id, data) values (1, 4);
|
||||
select @log;
|
||||
# Finally let us test INSERT ... ON DUPLICATE KEY UPDATE ...
|
||||
set @log:= "";
|
||||
insert into t1 (id, data) values (1, 5), (3, 3) on duplicate key update data= data + 2;
|
||||
select @log;
|
||||
|
||||
# This also drops associated triggers
|
||||
drop table t1;
|
||||
|
||||
|
||||
#
|
||||
# Test of wrong column specifiers in triggers
|
||||
#
|
||||
@ -249,3 +298,72 @@ create trigger trg1 before insert on t1 for each row set @a:= 1;
|
||||
# This should succeed
|
||||
drop database mysqltest;
|
||||
use test;
|
||||
|
||||
# Test for bug #5860 "Multi-table UPDATE does not activate update triggers"
|
||||
# We will also test how delete triggers wor for multi-table DELETE.
|
||||
create table t1 (i int, j int default 10, k int not null, key (k));
|
||||
create table t2 (i int);
|
||||
insert into t1 (i, k) values (1, 1);
|
||||
insert into t2 values (1);
|
||||
create trigger trg1 before update on t1 for each row set @a:= @a + new.j - old.j;
|
||||
create trigger trg2 after update on t1 for each row set @b:= "Fired";
|
||||
set @a:= 0, @b:= "";
|
||||
# Check that trigger works in case of update on the fly
|
||||
update t1, t2 set j = j + 10 where t1.i = t2.i;
|
||||
select @a, @b;
|
||||
insert into t1 values (2, 13, 2);
|
||||
insert into t2 values (2);
|
||||
set @a:= 0, @b:= "";
|
||||
# And now let us check that triggers work in case of multi-update which
|
||||
# is done through temporary tables...
|
||||
update t1, t2 set j = j + 15 where t1.i = t2.i and t1.k >= 2;
|
||||
select @a, @b;
|
||||
# Let us test delete triggers for multi-delete now.
|
||||
# We create triggers for both tables because we want test how they
|
||||
# work in both on-the-fly and via-temp-tables cases.
|
||||
create trigger trg3 before delete on t1 for each row set @c:= @c + old.j;
|
||||
create trigger trg4 before delete on t2 for each row set @d:= @d + old.i;
|
||||
create trigger trg5 after delete on t1 for each row set @e:= "After delete t1 fired";
|
||||
create trigger trg6 after delete on t2 for each row set @f:= "After delete t2 fired";
|
||||
set @c:= 0, @d:= 0, @e:= "", @f:= "";
|
||||
delete t1, t2 from t1, t2 where t1.i = t2.i;
|
||||
select @c, @d, @e, @f;
|
||||
# This also will drop triggers
|
||||
drop table t1, t2;
|
||||
|
||||
# Test for bug #6812 "Triggers are not activated for INSERT ... SELECT".
|
||||
# (We also check the fact that trigger modifies some field does not affect
|
||||
# value of next record inserted).
|
||||
delimiter |;
|
||||
create table t1 (i int, j int default 10)|
|
||||
create table t2 (i int)|
|
||||
insert into t2 values (1), (2)|
|
||||
create trigger trg1 before insert on t1 for each row
|
||||
begin
|
||||
if new.i = 1 then
|
||||
set new.j := 1;
|
||||
end if;
|
||||
end|
|
||||
create trigger trg2 after insert on t1 for each row set @a:= 1|
|
||||
set @a:= 0|
|
||||
insert into t1 (i) select * from t2|
|
||||
select * from t1|
|
||||
select @a|
|
||||
# This also will drop triggers
|
||||
drop table t1, t2|
|
||||
delimiter ;|
|
||||
|
||||
# Test for bug #8755 "Trigger is not activated by LOAD DATA"
|
||||
create table t1 (i int, j int, k int);
|
||||
create trigger trg1 before insert on t1 for each row set new.k = new.i;
|
||||
create trigger trg2 after insert on t1 for each row set @b:= "Fired";
|
||||
set @b:="";
|
||||
# Test triggers with file with separators
|
||||
load data infile '../../std_data/rpl_loaddata.dat' into table t1 (@a, i);
|
||||
select *, @b from t1;
|
||||
set @b:="";
|
||||
# Test triggers with fixed size row file
|
||||
load data infile '../../std_data/loaddata5.dat' into table t1 fields terminated by '' enclosed by '' (i, j);
|
||||
select *, @b from t1;
|
||||
# This also will drop triggers
|
||||
drop table t1;
|
||||
|
Reference in New Issue
Block a user