📄 sp-threads.test
字号:
# This test should work in embedded server after mysqltest is fixed-- source include/not_embedded.inc## Testing stored procedures with multiple connections,# except security/privilege tests, they go to sp-security.test#connect (con1root,localhost,root,,);connect (con2root,localhost,root,,);connect (con3root,localhost,root,,);connection con1root;use test;--disable_warningsdrop table if exists t1;--enable_warningscreate table t1 (s1 int, s2 int, s3 int);delimiter //; create procedure bug4934()begin insert into t1 values (1,0,1);end//delimiter ;//connection con2root;use test;call bug4934();select * from t1;connection con1root;drop table t1;create table t1 (s1 int, s2 int, s3 int);drop procedure bug4934;delimiter //; create procedure bug4934()beginend//delimiter ;//connection con2root;select * from t1;call bug4934();select * from t1;connection con1root;drop table t1;drop procedure bug4934;## BUG #9486 "Can't perform multi-update in stored procedure"#--disable_warningsdrop procedure if exists bug9486;drop table if exists t1, t2;--enable_warningscreate table t1 (id1 int, val int);create table t2 (id2 int);create procedure bug9486() update t1, t2 set val= 1 where id1=id2;call bug9486();# Let us check that SP invocation requires write lock for t2.connection con2root;lock tables t2 write;connection con1root;send call bug9486();connection con2root;--sleep 2# There should be call statement in locked state.--replace_column 1 # 3 localhost 6 #show processlist;unlock tables;connection con1root;reap;drop procedure bug9486;drop table t1, t2;## BUG#11158: Can't perform multi-delete in stored procedure#--disable_warningsdrop procedure if exists bug11158;--enable_warningscreate procedure bug11158() delete t1 from t1, t2 where t1.id = t2.id;create table t1 (id int, j int);insert into t1 values (1, 1), (2, 2);create table t2 (id int);insert into t2 values (1);# Procedure should work and cause proper effect (delete only first row)call bug11158();select * from t1;# Also let us test that we obtain only read (and thus non exclusive) lock# for table from which we are not going to delete rows.connection con2root;lock tables t2 read;connection con1root;call bug11158();connection con2root;unlock tables;connection con1root;# Clean-updrop procedure bug11158;drop table t1, t2;## BUG#11554: Server crashes on statement indirectly using non-cached function#--disable_warningsdrop function if exists bug11554;drop view if exists v1;--enable_warningscreate table t1 (i int);create function bug11554 () returns int return 1;create view v1 as select bug11554() as f;connection con2root;# This should not crash serverinsert into t1 (select f from v1);# Clean-upconnection con1root;drop function bug11554;drop table t1;drop view v1;# BUG#12228 --disable_warningsdrop procedure if exists p1;drop procedure if exists p2;--enable_warningsconnection con1root;delimiter |;create table t1 (s1 int)|create procedure p1() select * from t1|create procedure p2()begin insert into t1 values (1); call p1(); select * from t1;end|delimiter ;|connection con2root;use test;lock table t1 write;connection con1root;send call p2();connection con3root;use test;drop procedure p1;create procedure p1() select * from t1;connection con2root;unlock tables;connection con1root;# Crash will be here if we hit BUG#12228 reap;drop procedure p1;drop procedure p2;drop table t1;## BUG#NNNN: New bug synopsis##--disable_warnings#drop procedure if exists bugNNNN;#--enable_warnings#create procedure bugNNNN...
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -