mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 18:38:00 +03:00 
			
		
		
		
	This is a partial port of my patch in MySQL 8.0. In MySQL 8.0, all InnoDB references to DBUG_OFF were replaced with UNIV_DEBUG. We will not do that in MariaDB. InnoDB used two independent compile-time flags that distinguish debug and non-debug builds, which is confusing. Also, make ut_ad() and alias of DBUG_ASSERT().
		
			
				
	
	
		
			127 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			127 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| create table innodb_normal(c1 bigint not null, b char(200)) engine=innodb;
 | |
| create table innodb_compact(c1 bigint not null, b char(200)) engine=innodb row_format=compact encrypted=yes encryption_key_id=1;
 | |
| create table innodb_dynamic(c1 bigint not null, b char(200)) engine=innodb row_format=dynamic encrypted=yes encryption_key_id=3;
 | |
| ERROR HY000: Can't create table `test`.`innodb_dynamic` (errno: 140 "Wrong create options")
 | |
| show warnings;
 | |
| Level	Code	Message
 | |
| Warning	140	InnoDB: ENCRYPTION_KEY_ID 3 not available
 | |
| Error	1005	Can't create table `test`.`innodb_dynamic` (errno: 140 "Wrong create options")
 | |
| Warning	1030	Got error 140 "Wrong create options" from storage engine InnoDB
 | |
| create table innodb_dynamic(c1 bigint not null, b char(200)) engine=innodb row_format=dynamic encrypted=yes encryption_key_id=33;
 | |
| create table innodb_redundant(c1 bigint not null, b char(200))  engine=innodb row_format=redundant encrypted=yes encryption_key_id=4;
 | |
| show create table innodb_compact;
 | |
| Table	Create Table
 | |
| innodb_compact	CREATE TABLE `innodb_compact` (
 | |
|   `c1` bigint(20) NOT NULL,
 | |
|   `b` char(200) DEFAULT NULL
 | |
| ) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=COMPACT `encrypted`=yes `encryption_key_id`=1
 | |
| show create table innodb_dynamic;
 | |
| Table	Create Table
 | |
| innodb_dynamic	CREATE TABLE `innodb_dynamic` (
 | |
|   `c1` bigint(20) NOT NULL,
 | |
|   `b` char(200) DEFAULT NULL
 | |
| ) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=DYNAMIC `encrypted`=yes `encryption_key_id`=33
 | |
| show create table innodb_redundant;
 | |
| Table	Create Table
 | |
| innodb_redundant	CREATE TABLE `innodb_redundant` (
 | |
|   `c1` bigint(20) NOT NULL,
 | |
|   `b` char(200) DEFAULT NULL
 | |
| ) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=REDUNDANT `encrypted`=yes `encryption_key_id`=4
 | |
| create procedure innodb_insert_proc (repeat_count int)
 | |
| begin
 | |
| declare current_num int;
 | |
| set current_num = 0;
 | |
| while current_num < repeat_count do
 | |
| insert into innodb_normal values(current_num, substring(MD5(RAND()), -150));
 | |
| set current_num = current_num + 1;
 | |
| end while;
 | |
| end//
 | |
| commit;
 | |
| set autocommit=0;
 | |
| call innodb_insert_proc(5000);
 | |
| commit;
 | |
| set autocommit=1;
 | |
| insert into innodb_compact select * from innodb_normal;
 | |
| insert into innodb_dynamic select * from innodb_normal;
 | |
| insert into innodb_redundant select * from innodb_normal;
 | |
| update innodb_compact set c1 = c1 + 1;
 | |
| update innodb_dynamic set c1 = c1 + 1;
 | |
| update innodb_redundant set c1 = c1 + 1;
 | |
| select count(*) from innodb_compact where c1 < 1500000;
 | |
| count(*)
 | |
| 5000
 | |
| select count(*) from innodb_dynamic where c1 < 1500000;
 | |
| count(*)
 | |
| 5000
 | |
| select count(*) from innodb_redundant where c1 < 1500000;
 | |
| count(*)
 | |
| 5000
 | |
| update innodb_compact set c1 = c1 + 1;
 | |
| update innodb_dynamic set c1 = c1 + 1;
 | |
| update innodb_redundant set c1 = c1 + 1;
 | |
| select count(*) from innodb_compact where c1 < 1500000;
 | |
| count(*)
 | |
| 5000
 | |
| select count(*) from innodb_dynamic where c1 < 1500000;
 | |
| count(*)
 | |
| 5000
 | |
| select count(*) from innodb_redundant where c1 < 1500000;
 | |
| count(*)
 | |
| 5000
 | |
| alter table innodb_compact engine=innodb encrypted=DEFAULT encryption_key_id=DEFAULT;
 | |
| show create table innodb_compact;
 | |
| Table	Create Table
 | |
| innodb_compact	CREATE TABLE `innodb_compact` (
 | |
|   `c1` bigint(20) NOT NULL,
 | |
|   `b` char(200) DEFAULT NULL
 | |
| ) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=COMPACT
 | |
| alter table innodb_dynamic engine=innodb encrypted=DEFAULT encryption_key_id=DEFAULT;
 | |
| show create table innodb_dynamic;
 | |
| Table	Create Table
 | |
| innodb_dynamic	CREATE TABLE `innodb_dynamic` (
 | |
|   `c1` bigint(20) NOT NULL,
 | |
|   `b` char(200) DEFAULT NULL
 | |
| ) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=DYNAMIC
 | |
| alter table innodb_redundant engine=innodb encrypted=DEFAULT encryption_key_id=DEFAULT;
 | |
| show create table innodb_redundant;
 | |
| Table	Create Table
 | |
| innodb_redundant	CREATE TABLE `innodb_redundant` (
 | |
|   `c1` bigint(20) NOT NULL,
 | |
|   `b` char(200) DEFAULT NULL
 | |
| ) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=REDUNDANT
 | |
| show create table innodb_compact;
 | |
| Table	Create Table
 | |
| innodb_compact	CREATE TABLE `innodb_compact` (
 | |
|   `c1` bigint(20) NOT NULL,
 | |
|   `b` char(200) DEFAULT NULL
 | |
| ) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=COMPACT
 | |
| show create table innodb_dynamic;
 | |
| Table	Create Table
 | |
| innodb_dynamic	CREATE TABLE `innodb_dynamic` (
 | |
|   `c1` bigint(20) NOT NULL,
 | |
|   `b` char(200) DEFAULT NULL
 | |
| ) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=DYNAMIC
 | |
| show create table innodb_redundant;
 | |
| Table	Create Table
 | |
| innodb_redundant	CREATE TABLE `innodb_redundant` (
 | |
|   `c1` bigint(20) NOT NULL,
 | |
|   `b` char(200) DEFAULT NULL
 | |
| ) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=REDUNDANT
 | |
| update innodb_compact set c1 = c1 + 1;
 | |
| update innodb_dynamic set c1 = c1 + 1;
 | |
| update innodb_redundant set c1 = c1 + 1;
 | |
| select count(*) from innodb_compact where c1 < 1500000;
 | |
| count(*)
 | |
| 5000
 | |
| select count(*) from innodb_dynamic where c1 < 1500000;
 | |
| count(*)
 | |
| 5000
 | |
| select count(*) from innodb_redundant where c1 < 1500000;
 | |
| count(*)
 | |
| 5000
 | |
| drop procedure innodb_insert_proc;
 | |
| drop table innodb_normal;
 | |
| drop table innodb_compact;
 | |
| drop table innodb_dynamic;
 | |
| drop table innodb_redundant;
 |