mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-31 15:50:51 +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.
mysql-test/mysql-test-run.pl:
  bug25714
    implement support to run C test for bug25714
sql/ha_federated.cc:
  bug25714
    The storage engine instance property auto_increment_value was not
    being set.
    mysql_insert() requires that the storage engine updates the row with
    the auto-increment value, especially when only inserting one row.
    Implement support for ha_federated::info(HA_STATUS_AUTO)
tests/Makefile.am:
  bug25714
    build C test for bug
mysql-test/include/have_bug25714.inc:
  New BitKeeper file ``mysql-test/include/have_bug25714.inc''
mysql-test/r/federated_bug_25714.result:
  New BitKeeper file ``mysql-test/r/federated_bug_25714.result''
mysql-test/r/have_bug25714.require:
  New BitKeeper file ``mysql-test/r/have_bug25714.require''
mysql-test/t/federated_bug_25714.test:
  New BitKeeper file ``mysql-test/t/federated_bug_25714.test''
tests/bug25714.c:
  New BitKeeper file ``tests/bug25714.c''
		
	
		
			
				
	
	
		
			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;
 | |
| 
 |