mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 17:08:14 +02:00 
			
		
		
		
	 1242eb3d32
			
		
	
	
	1242eb3d32
	
	
	
		
			
			This was to remove a performance regression between 10.3 and 10.4 In 10.5 we will have a better implementation of records_in_range that will enable us to get more statistics. This change was not done in 10.4 because the 10.5 will be part of a larger change that is not suitable for the GA 10.4 version Other things: - Changed default handler block_size to 8192 to fix things statistics for engines that doesn't set the block size. - Fixed a bug in spider when using multiple part const ranges (Patch from Kentoku)
		
			
				
	
	
		
			169 lines
		
	
	
	
		
			3.8 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			169 lines
		
	
	
	
		
			3.8 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| drop table if exists t1, t2;
 | |
| create table t1 (
 | |
| a int not null auto_increment,
 | |
| b char(16) not null,
 | |
| primary key (a),
 | |
| key (b)
 | |
| );
 | |
| create table t2(
 | |
| a int not null auto_increment,
 | |
| b char(16) not null,
 | |
| primary key (a),
 | |
| key (b)
 | |
| );
 | |
| insert into t1(b) values 
 | |
| ('test0'),
 | |
| ('test1'),
 | |
| ('test2'),
 | |
| ('test3'),
 | |
| ('test4'),
 | |
| ('test5'),
 | |
| ('test6'),
 | |
| ('test7');
 | |
| insert into t2(b) select b from t1;
 | |
| insert into t1(b) select b from t2;
 | |
| insert into t2(b) select b from t1;
 | |
| insert into t1(b) select b from t2;
 | |
| insert into t2(b) select b from t1;
 | |
| insert into t1(b) select b from t2;
 | |
| insert into t2(b) select b from t1;
 | |
| insert into t1(b) select b from t2;
 | |
| insert into t2(b) select b from t1;
 | |
| insert into t1(b) select b from t2;
 | |
| insert into t2(b) select b from t1;
 | |
| insert into t1(b) select b from t2;
 | |
| insert into t2(b) select b from t1;
 | |
| insert into t1(b) select b from t2;
 | |
| insert into t2(b) select b from t1;
 | |
| insert into t1(b) select b from t2;
 | |
| insert into t2(b) select b from t1;
 | |
| insert into t1(b) select b from t2;
 | |
| select count(*) from t1;
 | |
| count(*)
 | |
| 33448
 | |
| select count(*) from t2;
 | |
| count(*)
 | |
| 20672
 | |
| flush tables;
 | |
| flush status;
 | |
| show status like "key_read%";
 | |
| Variable_name	Value
 | |
| Key_read_requests	0
 | |
| Key_reads	0
 | |
| select count(*) from t1 where b = 'test1';
 | |
| count(*)
 | |
| 4181
 | |
| show status like "key_read%";
 | |
| Variable_name	Value
 | |
| Key_read_requests	294
 | |
| Key_reads	60
 | |
| select count(*) from t1 where b = 'test1';
 | |
| count(*)
 | |
| 4181
 | |
| show status like "key_read%";
 | |
| Variable_name	Value
 | |
| Key_read_requests	588
 | |
| Key_reads	60
 | |
| flush tables;
 | |
| flush status;
 | |
| select @@preload_buffer_size;
 | |
| @@preload_buffer_size
 | |
| 32768
 | |
| load index into cache t1;
 | |
| Table	Op	Msg_type	Msg_text
 | |
| test.t1	preload_keys	status	OK
 | |
| show status like "key_read%";
 | |
| Variable_name	Value
 | |
| Key_read_requests	774
 | |
| Key_reads	774
 | |
| select count(*) from t1 where b = 'test1';
 | |
| count(*)
 | |
| 4181
 | |
| show status like "key_read%";
 | |
| Variable_name	Value
 | |
| Key_read_requests	1068
 | |
| Key_reads	774
 | |
| flush tables;
 | |
| flush status;
 | |
| show status like "key_read%";
 | |
| Variable_name	Value
 | |
| Key_read_requests	0
 | |
| Key_reads	0
 | |
| set session preload_buffer_size=256*1024;
 | |
| select @@preload_buffer_size;
 | |
| @@preload_buffer_size
 | |
| 262144
 | |
| load index into cache t1 ignore leaves;
 | |
| Table	Op	Msg_type	Msg_text
 | |
| test.t1	preload_keys	status	OK
 | |
| show status like "key_read%";
 | |
| Variable_name	Value
 | |
| Key_read_requests	17
 | |
| Key_reads	17
 | |
| select count(*) from t1 where b = 'test1';
 | |
| count(*)
 | |
| 4181
 | |
| show status like "key_read%";
 | |
| Variable_name	Value
 | |
| Key_read_requests	311
 | |
| Key_reads	75
 | |
| flush tables;
 | |
| flush status;
 | |
| show status like "key_read%";
 | |
| Variable_name	Value
 | |
| Key_read_requests	0
 | |
| Key_reads	0
 | |
| set session preload_buffer_size=1*1024;
 | |
| select @@preload_buffer_size;
 | |
| @@preload_buffer_size
 | |
| 1024
 | |
| load index into cache t1, t2 key (primary,b) ignore leaves;
 | |
| Table	Op	Msg_type	Msg_text
 | |
| test.t1	preload_keys	status	OK
 | |
| test.t2	preload_keys	status	OK
 | |
| show status like "key_read%";
 | |
| Variable_name	Value
 | |
| Key_read_requests	785
 | |
| Key_reads	785
 | |
| select count(*) from t1 where b = 'test1';
 | |
| count(*)
 | |
| 4181
 | |
| select count(*) from t2 where b = 'test1';
 | |
| count(*)
 | |
| 2584
 | |
| show status like "key_read%";
 | |
| Variable_name	Value
 | |
| Key_read_requests	1266
 | |
| Key_reads	821
 | |
| flush tables;
 | |
| flush status;
 | |
| show status like "key_read%";
 | |
| Variable_name	Value
 | |
| Key_read_requests	0
 | |
| Key_reads	0
 | |
| load index into cache t3, t2 key (primary,b) ;
 | |
| Table	Op	Msg_type	Msg_text
 | |
| test.t3	preload_keys	Error	Table 'test.t3' doesn't exist
 | |
| test.t3	preload_keys	status	Operation failed
 | |
| test.t2	preload_keys	status	OK
 | |
| show status like "key_read%";
 | |
| Variable_name	Value
 | |
| Key_read_requests	478
 | |
| Key_reads	478
 | |
| flush tables;
 | |
| flush status;
 | |
| show status like "key_read%";
 | |
| Variable_name	Value
 | |
| Key_read_requests	0
 | |
| Key_reads	0
 | |
| load index into cache t3 key (b), t2 key (c) ;
 | |
| Table	Op	Msg_type	Msg_text
 | |
| test.t3	preload_keys	Error	Table 'test.t3' doesn't exist
 | |
| test.t3	preload_keys	status	Operation failed
 | |
| test.t2	preload_keys	Error	Key 'c' doesn't exist in table 't2'
 | |
| test.t2	preload_keys	status	Operation failed
 | |
| show status like "key_read%";
 | |
| Variable_name	Value
 | |
| Key_read_requests	0
 | |
| Key_reads	0
 | |
| drop table t1, t2;
 |