mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 18:38:00 +03:00 
			
		
		
		
	Implementation of MDEV-7660 introduced unwanted incompatible change: modifications under LOCK TABLES with autocommit enabled are rolled back on disconnect. Previously everything was committed, because LOCK TABLES didn't adjust autocommit setting. This patch restores original behavior by reverting some changes done in MDEV-7660: - sql/sql_parse.cc: do not reset autocommit on LOCK TABLES - sql/sql_base.cc: do not set autocommit on UNLOCK TABLES - test cases: main.lock_tables_lost_commit, main.partition_explicit_prune, rpl.rpl_switch_stm_row_mixed, tokudb.nested_txn_implicit_commit, tokudb_bugs.db806 But it makes InnoDB tables under LOCK TABLES ... READ [LOCAL] not protected against DML. To restore protection some changes from WL#6671 were merged, specifically MDL_SHARED_READ_ONLY and test cases. WL#6671 merge highlights: - Not all tests merged. - In MySQL LOCK TABLES ... READ acquires MDL_SHARED_READ_ONLY for all engines, in MariaDB MDL_SHARED_READ is always acquired first and then upgraded to MDL_SHARED_READ_ONLY for InnoDB only. - The above allows us to omit MDL_SHARED_WRITE_LOW_PRIO implementation in MariaDB, which is rather useless with InnoDB. In MySQL it is needed to preserve locking behavior between low priority writes and LOCK TABLES ... READ for non-InnoDB engines (covered by sys_vars.sql_low_priority_updates_func). - Omitted HA_NO_READ_LOCAL_LOCK, we rely on lock_count() instead. - Omitted "piglets": in MariaDB stream of DML against InnoDB table may lead to concurrent LOCK TABLES ... READ starvation. - HANDLER ... OPEN acquires MDL_SHARED_READ instead of MDL_SHARED in MariaDB. - Omitted SNRW->X MDL lock upgrade for IMPORT/DISCARD TABLESPAECE under LOCK TABLES. - Omitted strong locks for views, triggers and SP under LOCK TABLES. - Omitted IX schema lock for LOCK TABLES READ. - Omitted deadlock weight juggling for LOCK TABLES. Full WL#6671 merge status: - innodb.innodb-lock: fully merged - main.alter_table: not merged due to different HANDLER solution - main.debug_sync: fully merged - main.handler_innodb: not merged due to different HANDLER solution - main.handler_myisam: not merged due to different HANDLER solution - main.innodb_mysql_lock: fully merged - main.insert_notembedded: fully merged - main.lock: not merged (due to no strong locks for views) - main.lock_multi: not merged - main.lock_sync: fully merged (partially in MDEV-7660) - main.mdl_sync: not merged - main.partition_debug_sync: not merged due to different HANDLER solution - main.status: fully merged - main.view: fully merged - perfschema.mdl_func: not merged (no such test in MariaDB) - perfschema.table_aggregate_global_2u_2t: not merged (didn't fail in MariaDB) - perfschema.table_aggregate_global_2u_3t: not merged (didn't fail in MariaDB) - perfschema.table_aggregate_global_4u_2t: not merged (didn't fail in MariaDB) - perfschema.table_aggregate_global_4u_3t: not merged (didn't fail in MariaDB) - perfschema.table_aggregate_hist_2u_2t: not merged (didn't fail in MariaDB) - perfschema.table_aggregate_hist_2u_3t: not merged (didn't fail in MariaDB) - perfschema.table_aggregate_hist_4u_2t: not merged (didn't fail in MariaDB) - perfschema.table_aggregate_hist_4u_3t: not merged (didn't fail in MariaDB) - perfschema.table_aggregate_thread_2u_2t: not merged (didn't fail in MariaDB) - perfschema.table_aggregate_thread_2u_3t: not merged (didn't fail in MariaDB) - perfschema.table_aggregate_thread_4u_2t: not merged (didn't fail in MariaDB) - perfschema.table_aggregate_thread_4u_3t: not merged (didn't fail in MariaDB) - perfschema.table_lock_aggregate_global_2u_2t: not merged (didn't fail in MariaDB) - perfschema.table_lock_aggregate_global_2u_3t: not merged (didn't fail in MariaDB) - perfschema.table_lock_aggregate_global_4u_2t: not merged (didn't fail in MariaDB) - perfschema.table_lock_aggregate_global_4u_3t: not merged (didn't fail in MariaDB) - perfschema.table_lock_aggregate_hist_2u_2t: not merged (didn't fail in MariaDB) - perfschema.table_lock_aggregate_hist_2u_3t: not merged (didn't fail in MariaDB) - perfschema.table_lock_aggregate_hist_4u_2t: not merged (didn't fail in MariaDB) - perfschema.table_lock_aggregate_hist_4u_3t: not merged (didn't fail in MariaDB) - perfschema.table_lock_aggregate_thread_2u_2t: not merged (didn't fail in MariaDB) - perfschema.table_lock_aggregate_thread_2u_3t: not merged (didn't fail in MariaDB) - perfschema.table_lock_aggregate_thread_4u_2t: not merged (didn't fail in MariaDB) - perfschema.table_lock_aggregate_thread_4u_3t: not merged (didn't fail in MariaDB) - sys_vars.sql_low_priority_updates_func: not merged - include/thr_rwlock.h: not merged, rw_pr_lock_assert_write_owner and rw_pr_lock_assert_not_write_owner are macros in MariaDB - sql/handler.h: not merged (HA_NO_READ_LOCAL_LOCK) - sql/mdl.cc: partially merged (MDL_SHARED_READ_ONLY only) - sql/mdl.h: partially merged (MDL_SHARED_READ_ONLY only) - sql/lock.cc: fully merged - sql/sp_head.cc: not merged - sql/sp_head.h: not merged - sql/sql_base.cc: partially merged (MDL_SHARED_READ_ONLY only) - sql/sql_base.h: not merged - sql/sql_class.cc: fully merged - sql/sql_class.h: fully merged - sql/sql_handler.cc: merged partially (different solution in MariaDB) - sql/sql_parse.cc: partially merged, mostly omitted low priority write part - sql/sql_reload.cc: not merged comment change - sql/sql_table.cc: not merged SNRW->X upgrade for IMPORT/DISCARD TABLESPACE - sql/sql_view.cc: not merged - sql/sql_yacc.yy: not merged (MDL_SHARED_WRITE_LOW_PRIO, MDL_SHARED_READ_ONLY) - sql/table.cc: not merged (MDL_SHARED_WRITE_LOW_PRIO) - sql/table.h: not merged (MDL_SHARED_WRITE_LOW_PRIO) - sql/trigger.cc: not merged - storage/innobase/handler/ha_innodb.cc: merged store_lock()/lock_count() changes (in MDEV-7660), didn't merge HA_NO_READ_LOCAL_LOCK - storage/innobase/handler/ha_innodb.h: fully merged in MDEV-7660 - storage/myisammrg/ha_myisammrg.cc: not merged comment change - storage/perfschema/table_helper.cc: not merged (no MDL support in MariaDB PFS) - unittest/gunit/mdl-t.cc: not merged - unittest/gunit/mdl_sync-t.cc: not merged MariaDB specific changes: - handler.heap: different HANDLER solution, MDEV-7660 - handler.innodb: different HANDLER solution, MDEV-7660 - handler.interface: different HANDLER solution, MDEV-7660 - handler.myisam: different HANDLER solution, MDEV-7660 - main.mdl_sync: MDEV-7660 specific changes - main.partition_debug_sync: removed test due to different HANDLER solution, MDEV-7660 - main.truncate_coverage: removed test due to different HANDLER solution, MDEV-7660 - mysql-test/include/mtr_warnings.sql: additional cleanup, MDEV-7660 - mysql-test/lib/v1/mtr_report.pl: additional cleanup, MDEV-7660 - plugin/metadata_lock_info/metadata_lock_info.cc: not in MySQL - sql/sql_handler.cc: MariaDB specific fix for mysql_ha_read(), MDEV-7660
		
			
				
	
	
		
			161 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			161 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| -- source include/not_embedded.inc
 | |
| 
 | |
| set local sql_mode="";
 | |
| set global sql_mode="";
 | |
| 
 | |
| --disable_warnings
 | |
| drop table if exists t1;
 | |
| --enable_warnings
 | |
| 
 | |
| # Test for INSERT DELAYED INTO a <view>
 | |
| # BUG#13683: INSERT DELAYED into a view creates an infinite loop
 | |
| #
 | |
| 
 | |
| create table t1 (n int);
 | |
| create view  v1 as select * from t1;
 | |
| --error 1347
 | |
| insert delayed into v1 values (1);
 | |
| drop table t1;
 | |
| drop view  v1;
 | |
| 
 | |
| #
 | |
| # Bug #20989: View '(null).(null)' references invalid table(s)... on
 | |
| #             SQL SECURITY INVOKER
 | |
| #
 | |
| # this is really the fact that REPLACE ... SELECT required additional
 | |
| # INSERT privs (on tables that are part of a view) over the related
 | |
| # REPLACE, SELECT
 | |
| #
 | |
| 
 | |
| CREATE DATABASE meow;
 | |
| 
 | |
| connect (root,localhost,root,,meow);
 | |
| connection root;
 | |
| 
 | |
| CREATE TABLE table_target   ( mexs_id CHAR(8), messzeit TIMESTAMP, PRIMARY KEY (mexs_id));
 | |
| CREATE TABLE table_target2  ( mexs_id CHAR(8), messzeit TIMESTAMP, PRIMARY KEY (mexs_id));
 | |
| CREATE TABLE table_target3  ( mexs_id CHAR(8), messzeit TIMESTAMP, PRIMARY KEY (mexs_id));
 | |
| CREATE VIEW view_target2 AS SELECT mexs_id,messzeit FROM table_target2;
 | |
| CREATE SQL SECURITY INVOKER VIEW view_target3 AS SELECT mexs_id,messzeit FROM table_target3;
 | |
| 
 | |
| CREATE TABLE table_stations ( mexs_id VARCHAR(8), icao VARCHAR(4), country CHAR(2), PRIMARY KEY (mexs_id), UNIQUE KEY icao (icao), KEY country (country), CONSTRAINT stations_ibfk_8 FOREIGN KEY (country) REFERENCES countries (country) ON UPDATE CASCADE);
 | |
| INSERT INTO table_stations VALUES ('87654321','XXXX','YY');
 | |
| 
 | |
| CREATE TABLE table_countries ( country CHAR(2), iso_short_en VARCHAR(64), PRIMARY KEY (country));
 | |
| INSERT INTO table_countries VALUES ('YY','Entenhausen');
 | |
| 
 | |
| CREATE ALGORITHM=MERGE SQL SECURITY INVOKER VIEW view_stations AS select table_stations.mexs_id AS mexs_id, table_stations.icao AS icao, table_stations.country AS landescode from (table_stations join table_countries on((table_stations.country = table_countries.country)));
 | |
| 
 | |
| CREATE TABLE table_source ( id varchar(4), datetime TIMESTAMP, PRIMARY KEY (id));
 | |
| INSERT INTO  table_source VALUES ('XXXX','2006-07-12 07:50:00');
 | |
| 
 | |
| GRANT  SELECT                ON table_source    TO   user20989@localhost;
 | |
| GRANT  SELECT                ON table_countries TO   user20989@localhost;
 | |
| GRANT  SELECT                ON table_stations  TO   user20989@localhost;
 | |
| GRANT  SELECT                ON view_stations   TO   user20989@localhost;
 | |
| GRANT  SELECT                ON table_target    TO   user20989@localhost;
 | |
| GRANT  SELECT                ON table_target2   TO   user20989@localhost;
 | |
| GRANT  INSERT,DELETE,SELECT  ON view_target3    TO   user20989@localhost;
 | |
| 
 | |
| connect (user20989,localhost,user20989,,meow);
 | |
| connection user20989;
 | |
| 
 | |
| --error 1142
 | |
| REPLACE INTO    table_target
 | |
| SELECT          stations.mexs_id AS mexs_id, datetime AS messzeit
 | |
| FROM            table_source
 | |
| INNER JOIN      view_stations AS stations
 | |
| ON              table_source.id = stations.icao
 | |
| LEFT JOIN       table_target AS old
 | |
| USING           (mexs_id);
 | |
| 
 | |
| --error 1142
 | |
| REPLACE INTO    view_target2
 | |
| SELECT          stations.mexs_id AS mexs_id, datetime AS messzeit
 | |
| FROM            table_source
 | |
| INNER JOIN      view_stations AS stations
 | |
| ON              table_source.id = stations.icao
 | |
| LEFT JOIN       view_target2 AS old
 | |
| USING           (mexs_id);
 | |
| 
 | |
| --error 1356
 | |
| REPLACE INTO    view_target3
 | |
| SELECT          stations.mexs_id AS mexs_id, datetime AS messzeit
 | |
| FROM            table_source
 | |
| INNER JOIN      view_stations AS stations
 | |
| ON              table_source.id = stations.icao
 | |
| LEFT JOIN       view_target3 AS old
 | |
| USING           (mexs_id);
 | |
| 
 | |
| connection root;
 | |
| disconnect user20989;
 | |
| 
 | |
| GRANT  INSERT,DELETE         ON table_target    TO   user20989@localhost;
 | |
| GRANT  INSERT,DELETE,SELECT  ON view_target2    TO   user20989@localhost;
 | |
| GRANT  INSERT,DELETE,SELECT  ON table_target3   TO   user20989@localhost;
 | |
| 
 | |
| connect (user20989,localhost,user20989,,meow);
 | |
| connection user20989;
 | |
| 
 | |
| REPLACE INTO    table_target
 | |
| SELECT          stations.mexs_id AS mexs_id, datetime AS messzeit
 | |
| FROM            table_source
 | |
| INNER JOIN      view_stations AS stations
 | |
| ON              table_source.id = stations.icao
 | |
| LEFT JOIN       table_target AS old
 | |
| USING           (mexs_id);
 | |
| 
 | |
| --error 1142
 | |
| REPLACE INTO    table_target2 VALUES ('00X45Y78','2006-07-12 07:50:00');
 | |
| REPLACE INTO    view_target2  VALUES ('12X45Y78','2006-07-12 07:50:00');
 | |
| 
 | |
| SELECT          stations.mexs_id AS mexs_id, datetime AS messzeit
 | |
| FROM            table_source
 | |
| INNER JOIN      view_stations AS stations
 | |
| ON              table_source.id = stations.icao
 | |
| LEFT JOIN       view_target2 AS old
 | |
| USING           (mexs_id);
 | |
| 
 | |
| REPLACE INTO    view_target2
 | |
| SELECT          stations.mexs_id AS mexs_id, datetime AS messzeit
 | |
| FROM            table_source
 | |
| INNER JOIN      view_stations AS stations
 | |
| ON              table_source.id = stations.icao
 | |
| LEFT JOIN       view_target2 AS old
 | |
| USING           (mexs_id);
 | |
| 
 | |
| REPLACE INTO    view_target3
 | |
| SELECT          stations.mexs_id AS mexs_id, datetime AS messzeit
 | |
| FROM            table_source
 | |
| INNER JOIN      view_stations AS stations
 | |
| ON              table_source.id = stations.icao
 | |
| LEFT JOIN       view_target3 AS old
 | |
| USING           (mexs_id);
 | |
| 
 | |
| connection root;
 | |
| disconnect user20989;
 | |
| 
 | |
| SELECT * FROM table_target;
 | |
| SELECT * FROM view_target2;
 | |
| SELECT * FROM view_target3;
 | |
| 
 | |
| DROP VIEW  view_stations;
 | |
| DROP TABLE table_source;
 | |
| DROP TABLE table_countries;
 | |
| DROP TABLE table_stations;
 | |
| DROP TABLE table_target;
 | |
| DROP TABLE table_target2;
 | |
| DROP TABLE table_target3;
 | |
| DROP VIEW  view_target2;
 | |
| DROP VIEW  view_target3;
 | |
| DROP USER  user20989@localhost;
 | |
| 
 | |
| disconnect root;
 | |
| 
 | |
| connection default;
 | |
| 
 | |
| DROP DATABASE meow;
 | |
| 
 | |
| set local sql_mode=default;
 | |
| set global sql_mode=default;
 |