mirror of
https://github.com/MariaDB/server.git
synced 2025-01-19 21:42:35 +01:00
cab1dc628c
New multi-key-cache handling. This was needed becasue the old one didn't work reliable with MERGE tables. ALTER TABLE table_name ... CHARACTER SET ... now changes all char/varchar/text columns to the given character set (One must use ALTER TABLE ... DEFAULT CHARACTER SET ... to change the default character set) Fixed that have_compress is detected properly (fixes problems with func_compress.test on platforms without zlib) New syntax for CACHE INDEX ('keys' is optional if no index name is given and one mentions the key cache name only ones) Removed compiler warnings Added mysql_set_server_option() to allow clients like PHP to easaily set/reset the multi-statement flag.
100 lines
2.4 KiB
Text
100 lines
2.4 KiB
Text
#
|
|
# Testing of PRELOAD
|
|
#
|
|
|
|
--disable_warnings
|
|
drop table if exists t1, t2;
|
|
--enable_warnings
|
|
|
|
|
|
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;
|
|
select count(*) from t2;
|
|
|
|
flush tables; flush status;
|
|
show status like "key_read%";
|
|
|
|
select count(*) from t1 where b = 'test1';
|
|
show status like "key_read%";
|
|
select count(*) from t1 where b = 'test1';
|
|
show status like "key_read%";
|
|
|
|
flush tables; flush status;
|
|
select @@preload_buffer_size;
|
|
load index into cache t1;
|
|
show status like "key_read%";
|
|
select count(*) from t1 where b = 'test1';
|
|
show status like "key_read%";
|
|
|
|
flush tables; flush status;
|
|
show status like "key_read%";
|
|
set session preload_buffer_size=256*1024;
|
|
select @@preload_buffer_size;
|
|
load index into cache t1 ignore leaves;
|
|
show status like "key_read%";
|
|
select count(*) from t1 where b = 'test1';
|
|
show status like "key_read%";
|
|
|
|
flush tables; flush status;
|
|
show status like "key_read%";
|
|
set session preload_buffer_size=1*1024;
|
|
select @@preload_buffer_size;
|
|
load index into cache t1, t2 keys (primary,b) ignore leaves;
|
|
show status like "key_read%";
|
|
select count(*) from t1 where b = 'test1';
|
|
select count(*) from t2 where b = 'test1';
|
|
show status like "key_read%";
|
|
|
|
flush tables; flush status;
|
|
show status like "key_read%";
|
|
load index into cache t3, t2 keys (primary,b) ;
|
|
show status like "key_read%";
|
|
|
|
flush tables; flush status;
|
|
show status like "key_read%";
|
|
load index into cache t3 keys (b), t2 keys (c) ;
|
|
show status like "key_read%";
|
|
|
|
drop table t1, t2;
|