mirror of
				https://github.com/MariaDB/server.git
				synced 2025-11-03 14:33:32 +03:00 
			
		
		
		
	"getGeneratedKeys() does not work with FEDERATED table" mysql_insert() expected the storage engine to update the row data during the write_row() operation with the value of the new auto- increment field. The field must be updated when only one row has been inserted as mysql_insert() would ignore the thd->last_insert. This patch implements HA_STATUS_AUTO support in ha_federated::info() and ensures that ha_federated::write_row() does update the row's auto-increment value. The test case was written in C as the protocol's 'id' value is accessible through libmysqlclient and not via SQL statements. mysql-test-run.pl was extended to enable running the test binary.
		
			
				
	
	
		
			48 lines
		
	
	
		
			1012 B
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1012 B
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
--source include/have_bug25714.inc
 | 
						|
source include/federated.inc;
 | 
						|
 | 
						|
 | 
						|
connection slave;
 | 
						|
--disable_warnings
 | 
						|
DROP TABLE IF EXISTS federated.bug_13118_table;
 | 
						|
--enable_warnings
 | 
						|
 | 
						|
CREATE TABLE federated.t1 (
 | 
						|
    `id` int auto_increment primary key, 
 | 
						|
	`value` int
 | 
						|
    ) ENGINE=MyISAM;
 | 
						|
INSERT INTO federated.t1 SET value=1;
 | 
						|
INSERT INTO federated.t1 SET value=2;
 | 
						|
INSERT INTO federated.t1 SET value=2;
 | 
						|
 | 
						|
connection master;
 | 
						|
--disable_warnings
 | 
						|
DROP TABLE IF EXISTS federated.t1;
 | 
						|
--enable_warnings
 | 
						|
 | 
						|
--replace_result $SLAVE_MYPORT SLAVE_PORT
 | 
						|
eval CREATE TABLE federated.t1 (
 | 
						|
    `id` int auto_increment primary key, 
 | 
						|
	`value` int
 | 
						|
    ) ENGINE=FEDERATED
 | 
						|
    CONNECTION='mysql://root@127.0.0.1:$SLAVE_MYPORT/federated/t1';
 | 
						|
 | 
						|
SELECT * from federated.t1;
 | 
						|
 | 
						|
INSERT INTO federated.t1 SET value=4;
 | 
						|
 | 
						|
SELECT LAST_INSERT_ID();
 | 
						|
 | 
						|
--exec $MYSQL_BUG25714 $SLAVE_MYPORT
 | 
						|
--exec $MYSQL_BUG25714 $MASTER_MYPORT
 | 
						|
 | 
						|
SELECT * from federated.t1;
 | 
						|
 | 
						|
DROP TABLE federated.t1;
 | 
						|
connection slave;
 | 
						|
DROP TABLE federated.t1;
 | 
						|
 | 
						|
 | 
						|
source include/federated_cleanup.inc;
 | 
						|
 |