mirror of
				https://github.com/MariaDB/server.git
				synced 2025-11-03 14:33:32 +03:00 
			
		
		
		
	Now it supports queries returning several results (particularly important with the SP) include/mysql.h: embedded_query_result structure added libmysql/libmysql.c: embedded-server related fixes libmysqld/emb_qcache.cc: multiple-result support added libmysqld/embedded_priv.h: embedded_query_result struct implemented libmysqld/lib_sql.cc: multiple-result support added libmysqld/libmysqld.c: small fixes mysql-test/t/backup.test: test fixed mysql-test/t/binlog_stm_binlog.test: test fixed mysql-test/t/binlog_stm_blackhole.test: test fixed mysql-test/t/binlog_stm_ctype_cp932.test: test fixed mysql-test/t/compress.test: test fixed mysql-test/t/delayed.test: test fixed mysql-test/t/federated.test: test fixed mysql-test/t/federated_archive.test: test fixed mysql-test/t/federated_bug_13118.test: test fixed mysql-test/t/federated_transactions.test: test fixed mysql-test/t/flush_table.test: test fixed mysql-test/t/handler.test: test fixed mysql-test/t/init_connect.test: test fixed mysql-test/t/innodb.test: test fixed mysql-test/t/mysql.test: test fixed mysql-test/t/mysql_client_test.test: test fixed mysql-test/t/mysqltest.test: test fixed mysql-test/t/query_cache.test: test fixed mysql-test/t/query_cache_notembedded.test: test fixed mysql-test/t/read_only.test: test fixed mysql-test/t/skip_grants.test: test fixed mysql-test/t/sp-destruct.test: test fixed mysql-test/t/sp-error.test: test fixed mysql-test/t/sp-threads.test: test fixed mysql-test/t/sp.test: test fixed mysql-test/t/view.test: test fixed mysql-test/t/wait_timeout.test: test fixed sql-common/client.c: small fixes sql/mysqld.cc: embedded-server related fix sql/protocol.cc: embedded-server related fix sql/protocol.h: embedded-server related fix sql/sql_class.cc: embedded-server related fix sql/sql_class.h: embedded-server related fix sql/sql_cursor.cc: embedded-server related fix sql/sql_parse.cc: embedded-server related fix sql/sql_prepare.cc: embedded-server related fix
		
			
				
	
	
		
			186 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			186 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
# 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_warnings
 | 
						|
drop table if exists t1;
 | 
						|
--enable_warnings
 | 
						|
create 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()
 | 
						|
begin
 | 
						|
end//
 | 
						|
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_warnings
 | 
						|
drop procedure if exists bug9486;
 | 
						|
drop table if exists t1, t2;
 | 
						|
--enable_warnings
 | 
						|
create 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_warnings
 | 
						|
drop procedure if exists bug11158;
 | 
						|
--enable_warnings
 | 
						|
create 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-up
 | 
						|
drop procedure bug11158;
 | 
						|
drop table t1, t2;
 | 
						|
 | 
						|
#
 | 
						|
# BUG#11554: Server crashes on statement indirectly using non-cached function
 | 
						|
#
 | 
						|
--disable_warnings
 | 
						|
drop function if exists bug11554;
 | 
						|
drop view if exists v1;
 | 
						|
--enable_warnings
 | 
						|
create 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 server
 | 
						|
insert into t1 (select f from v1);
 | 
						|
# Clean-up
 | 
						|
connection con1root;
 | 
						|
drop function bug11554;
 | 
						|
drop table t1;
 | 
						|
drop view v1;
 | 
						|
 | 
						|
 | 
						|
# BUG#12228 
 | 
						|
--disable_warnings
 | 
						|
drop procedure if exists p1;
 | 
						|
drop procedure if exists p2;
 | 
						|
--enable_warnings
 | 
						|
 | 
						|
connection 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...
 | 
						|
 |