mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-30 04:26:45 +03:00 
			
		
		
		
	 5394a1a4bd
			
		
	
	5394a1a4bd
	
	
	
		
			
			In order to make multi-delete SP friendly we need to have all table locks for the elements of main statement table list properly set at the end of parsing. Also performed small cleanup: We don't need relink_tables_for_multidelete() any longer since the only case now when TABLE_LIST::correspondent_table is non-zero are tables in auxilary table list of multi-delete and these tables are handled specially in mysql_multi_delete_prepare().
		
			
				
	
	
		
			58 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| use test;
 | |
| drop table if exists t1;
 | |
| create table t1 (s1 int, s2 int, s3 int);
 | |
| create procedure bug4934()
 | |
| begin
 | |
| insert into t1 values (1,0,1);
 | |
| end//
 | |
| use test;
 | |
| call bug4934();
 | |
| select * from t1;
 | |
| s1	s2	s3
 | |
| 1	0	1
 | |
| drop table t1;
 | |
| create table t1 (s1 int, s2 int, s3 int);
 | |
| drop procedure bug4934;
 | |
| create procedure bug4934()
 | |
| begin
 | |
| end//
 | |
| select * from t1;
 | |
| s1	s2	s3
 | |
| call bug4934();
 | |
| select * from t1;
 | |
| s1	s2	s3
 | |
| drop table t1;
 | |
| drop procedure bug4934;
 | |
| drop procedure if exists bug9486;
 | |
| drop table if exists t1, t2;
 | |
| 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();
 | |
| lock tables t2 write;
 | |
|  call bug9486();
 | |
| show processlist;
 | |
| Id	User	Host	db	Command	Time	State	Info
 | |
| #	root	localhost	test	Sleep	#		NULL
 | |
| #	root	localhost	test	Query	#	Locked	call bug9486()
 | |
| #	root	localhost	test	Query	#	NULL	show processlist
 | |
| unlock tables;
 | |
| drop procedure bug9486;
 | |
| drop table t1, t2;
 | |
| drop procedure if exists bug11158;
 | |
| 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);
 | |
| call bug11158();
 | |
| select * from t1;
 | |
| id	j
 | |
| 2	2
 | |
| lock tables t2 read;
 | |
| call bug11158();
 | |
| unlock tables;
 | |
| drop procedure bug11158;
 | |
| drop table t1, t2;
 |