~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to tests/t/key_cache.test

  • Committer: Brian Aker
  • Date: 2010-01-27 18:58:12 UTC
  • Revision ID: brian@gaz-20100127185812-n62n0vwetnx8jrjy
Remove dead code.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
#
2
 
# Test of multiple key caches
 
2
# Test of the MyISAM key cache
3
3
#
4
4
--disable_warnings
5
5
drop table if exists t1, t2, t3;
6
6
--enable_warnings
7
7
 
8
 
SET @save_key_buffer=@@key_buffer_size;
 
8
SET @save_myisam_key_cache_size=@@myisam_key_cache_size;
 
9
SET @save_myisam_key_cache_block_size=@@myisam_key_cache_block_size;
 
10
SET @save_myisam_key_cache_division_limit=@@myisam_key_cache_division_limit;
 
11
SET @save_myisam_key_cache_age_threshold=@@myisam_key_cache_age_threshold;
9
12
 
10
 
SELECT @@key_buffer_size, @@small.key_buffer_size;
 
13
# Show default variables for MyISAM key cache
 
14
SELECT @@myisam_key_cache_size;
 
15
SELECT @@myisam_key_cache_block_size;
 
16
SELECT @@myisam_key_cache_division_limit;
 
17
SELECT @@myisam_key_cache_age_threshold;
11
18
 
12
19
# Change default key cache size
13
 
SET @@global.key_buffer_size=16*1024*1024;
14
 
SET @@global.default.key_buffer_size=16*1024*1024;
15
 
SET @@global.default.key_buffer_size=16*1024*1024;
 
20
SET @@global.myisam_key_cache_size=16*1024*1024;
16
21
 
17
 
SET @@global.small.key_buffer_size=1*1024*1024;
18
 
SET @@global.medium.key_buffer_size=4*1024*1024;
19
 
# Drop buffer
20
 
SET @@global.medium.key_buffer_size=0;
 
22
# Drop Key Cache (warning generated)
 
23
SET @@global.myisam_key_cache_size=0;
21
24
# Test double drop
22
 
SET @@global.medium.key_buffer_size=0;
 
25
SET @@global.myisam_key_cache_size=0;
 
26
 
 
27
# Change default key cache size
 
28
SET @@global.myisam_key_cache_size=16*1024*1024;
23
29
 
24
30
# Print key buffer with different syntaxes
25
 
SHOW VARIABLES like "key_buffer_size";
26
 
SELECT @@key_buffer_size;
27
 
SELECT @@global.key_buffer_size;
28
 
SELECT @@global.default.key_buffer_size;
29
 
SELECT @@global.default.`key_buffer_size`;
30
 
SELECT @@global.`default`.`key_buffer_size`;
31
 
SELECT @@`default`.key_buffer_size;
32
 
 
33
 
SELECT @@small.key_buffer_size;
34
 
SELECT @@medium.key_buffer_size;
35
 
 
36
 
SET @@global.key_buffer_size=@save_key_buffer;
 
31
SHOW VARIABLES like "myisam_key_cache_size";
 
32
SELECT @@myisam_key_cache_size;
 
33
SELECT @@global.myisam_key_cache_size;
 
34
SELECT @@global.myisam_key_cache_size;
 
35
SELECT @@global.`myisam_key_cache_size`;
 
36
SELECT @@global.`myisam_key_cache_size`;
 
37
SELECT @@myisam_key_cache_size;
 
38
 
 
39
SET @@global.myisam_key_cache_size=@save_myisam_key_cache_size;
37
40
 
38
41
#
39
42
# Errors
40
43
#
41
44
 
42
 
--error 1064
43
 
SELECT @@default.key_buffer_size;
44
 
--error 1272
 
45
SELECT @@myisam_key_cache_size;
 
46
-- error 1272
45
47
SELECT @@skr.storage_engine="test";
46
48
 
47
 
select @@keycache1.key_cache_block_size;
48
 
select @@keycache1.key_buffer_size;
49
 
set global keycache1.key_cache_block_size=2048;
50
 
select @@keycache1.key_buffer_size;
51
 
select @@keycache1.key_cache_block_size;
52
 
set global keycache1.key_buffer_size=1*1024*1024;
53
 
select @@keycache1.key_buffer_size;
54
 
select @@keycache1.key_cache_block_size;
55
 
set global keycache2.key_buffer_size=4*1024*1024;
56
 
select @@keycache2.key_buffer_size;
57
 
select @@keycache2.key_cache_block_size;
58
 
set global keycache1.key_buffer_size=0;
59
 
select @@keycache1.key_buffer_size;
60
 
select @@keycache1.key_cache_block_size;
61
 
select @@key_buffer_size;
62
 
select @@key_cache_block_size;
63
 
 
64
 
set global keycache1.key_buffer_size=1024*1024;
65
 
 
66
 
create table t1 (p int primary key, a char(10)) delay_key_write=1;
67
 
create table t2 (p int primary key, i int, a char(10), key k1(i), key k2(a));
68
 
 
69
 
show status like 'key_blocks_used';
70
 
 
71
 
# Following results differs on 64 and 32 bit systems because of different
72
 
# pointer sizes, which takes up different amount of space in key cache
73
 
 
74
 
--replace_result 1812 KEY_BLOCKS_UNUSED 1793 KEY_BLOCKS_UNUSED 1674 KEY_BLOCKS_UNUSED 1818 KEY_BLOCKS_UNUSED 1824 KEY_BLOCKS_UNUSED
75
 
show status like 'key_blocks_unused';
76
 
 
77
 
insert into t1 values (1, 'qqqq'), (11, 'yyyy');
78
 
insert into t2 values (1, 1, 'qqqq'), (2, 1, 'pppp'),
79
 
                      (3, 1, 'yyyy'), (4, 3, 'zzzz');
80
 
select * from t1;
81
 
select * from t2;
82
 
 
83
 
update t1 set p=2 where p=1;
84
 
update t2 set i=2 where i=1;
85
 
 
86
 
show status like 'key_blocks_used';
87
 
--replace_result 1808 KEY_BLOCKS_UNUSED 1789 KEY_BLOCKS_UNUSED 1670 KEY_BLOCKS_UNUSED 1814 KEY_BLOCKS_UNUSED 1820 KEY_BLOCKS_UNUSED
88
 
show status like 'key_blocks_unused';
89
 
 
90
 
cache index t1 key (`primary`) in keycache1;
91
 
 
92
 
explain select p from t1;
93
 
select p from t1;
94
 
explain select i from t2;
95
 
select i from t2;
96
 
explain select count(*) from t1, t2 where t1.p = t2.i;
97
 
select count(*) from t1, t2 where t1.p = t2.i;
98
 
 
99
 
cache index t2 in keycache1;
100
 
update t2 set p=p+1000, i=2 where a='qqqq';
101
 
cache index t2 in keycache2;
102
 
insert into t2 values (2000, 3, 'yyyy');
103
 
cache index t2 in keycache1;
104
 
update t2 set p=3000 where a='zzzz';
105
 
select * from t2;
106
 
explain select p from t2;
107
 
select p from t2;
108
 
explain select i from t2;
109
 
select i from t2;
110
 
explain select a from t2;
111
 
select a from t2;
112
 
 
113
 
# Test some error conditions
114
 
--error 1284
115
 
cache index t1 in unknown_key_cache;
116
 
cache index t1 key (unknown_key) in keycache1;
117
 
 
118
 
select @@keycache2.key_buffer_size;
119
 
select @@keycache2.key_cache_block_size;
120
 
set global keycache2.key_buffer_size=0;
121
 
select @@keycache2.key_buffer_size;
122
 
select @@keycache2.key_cache_block_size;
123
 
set global keycache2.key_buffer_size=1024*1024;
124
 
select @@keycache2.key_buffer_size;
125
 
 
126
 
update t2 set p=4000 where a='zzzz';
127
 
update t1 set p=p+1;
128
 
 
129
 
set global keycache1.key_buffer_size=0;
130
 
select * from t2;
131
 
select p from t2;
132
 
explain select i from t2;
133
 
select i from t2;
134
 
explain select a from t2;
135
 
select a from t2;
136
 
 
137
 
select * from t1;
138
 
select p from t1;
139
 
 
140
 
# Use the 'small' key cache
141
 
create table t3 (like t1);
142
 
cache index t3 in small;
143
 
insert into t3 select * from t1;
144
 
cache index t3 in keycache2;
145
 
cache index t1,t2 in default;
146
 
drop table t1,t2,t3;
147
 
 
148
 
show status like 'key_blocks_used';
149
 
--replace_result 1812 KEY_BLOCKS_UNUSED 1793 KEY_BLOCKS_UNUSED 1674 KEY_BLOCKS_UNUSED 1818 KEY_BLOCKS_UNUSED 1824 KEY_BLOCKS_UNUSED
150
 
show status like 'key_blocks_unused';
151
 
 
152
 
 
153
 
# Cleanup
154
 
# We don't reset keycache2 as we want to ensure that mysqld will reset it
155
 
set global keycache2.key_buffer_size=0;
 
49
-- error 1272
 
50
select @@keycache1.myisam_key_cache_block_size;
 
51
 
 
52
show status like 'key_blocks_used';
156
53
 
157
54
# Test to set up a too small size for a key cache (bug #2064)
158
 
set global keycache3.key_buffer_size=100;
159
 
set global keycache3.key_buffer_size=0;
160
 
 
161
 
# Test case for bug 6447
162
 
 
163
 
create table t1 (mytext text, FULLTEXT (mytext));
164
 
insert t1 values ('aaabbb');
165
 
 
166
 
check table t1;
167
 
set @my_key_cache_block_size= @@global.key_cache_block_size;
168
 
set GLOBAL key_cache_block_size=2048;
169
 
check table t1;
170
 
drop table t1;
171
 
# Restore the changed variable value
172
 
set global key_cache_block_size= @my_key_cache_block_size;
 
55
set global myisam_key_cache_size=100;
173
56
 
174
57
#
175
 
# Bug #19079: corrupted index when key_cache_block_size is not multiple of
 
58
# Bug #19079: corrupted index when myisam_key_cache_block_size is not multiple of
176
59
#             myisam_block_size
177
60
 
178
 
CREATE TABLE t1(a int NOT NULL AUTO_INCREMENT PRIMARY KEY);
179
 
SET @my_key_cache_block_size= @@global.key_cache_block_size;
180
 
SET GLOBAL key_cache_block_size=1536;
 
61
CREATE temporary TABLE t1(a int NOT NULL AUTO_INCREMENT PRIMARY KEY) ENGINE=MYISAM;
 
62
SET GLOBAL myisam_key_cache_block_size=1536;
181
63
INSERT INTO t1 VALUES (1);
182
 
SELECT @@key_cache_block_size;
 
64
SELECT @@myisam_key_cache_block_size;
183
65
CHECK TABLE t1;
184
66
DROP TABLE t1;
185
67
 
186
 
CREATE TABLE t1(a int NOT NULL AUTO_INCREMENT PRIMARY KEY, b int);
187
 
CREATE TABLE t2(a int NOT NULL AUTO_INCREMENT PRIMARY KEY, b int);
188
 
SET GLOBAL key_cache_block_size=1536;
 
68
CREATE TEMPORARY TABLE t1(a int NOT NULL AUTO_INCREMENT PRIMARY KEY, b int) ENGINE=MYISAM;
 
69
CREATE TEMPORARY TABLE t2(a int NOT NULL AUTO_INCREMENT PRIMARY KEY, b int) ENGINE=MYISAM;
 
70
SET GLOBAL myisam_key_cache_block_size=1536;
189
71
INSERT INTO t1 VALUES (1,0);
190
72
INSERT INTO t2(b) SELECT b FROM t1;
191
73
INSERT INTO t1(b) SELECT b FROM t2;
206
88
INSERT INTO t2(b) SELECT b FROM t1;
207
89
INSERT INTO t1(b) SELECT b FROM t2;
208
90
SELECT COUNT(*) FROM t1;
209
 
SELECT @@key_cache_block_size;
 
91
SELECT @@myisam_key_cache_block_size;
210
92
CHECK TABLE t1;
211
93
DROP TABLE t1,t2;
212
94
# Restore changed variables
213
 
set global key_cache_block_size= @my_key_cache_block_size;
214
 
 
215
 
#
216
 
# Bug#10473 - Can't set 'key_buffer_size' system variable to ZERO
217
 
# (One cannot drop the default key cache.)
218
 
#
219
 
set @@global.key_buffer_size=0;
220
 
select @@global.key_buffer_size;
221
 
 
222
 
#
223
 
# Bug#28478 - Improper key_cache_block_size corrupts MyISAM tables
224
 
#
225
 
SET @bug28478_key_cache_block_size= @@global.key_cache_block_size;
226
 
SET GLOBAL key_cache_block_size= 1536;
227
 
CREATE TABLE t1 (
 
95
set global myisam_key_cache_block_size= @save_myisam_key_cache_block_size;
 
96
 
 
97
#
 
98
# Bug#28478 - Improper myisam_key_cache_block_size corrupts MyISAM tables
 
99
#
 
100
SET GLOBAL myisam_key_cache_block_size= 1536;
 
101
CREATE TEMPORARY TABLE t1 (
228
102
  id BIGINT NOT NULL AUTO_INCREMENT PRIMARY KEY,
229
 
  c1 CHAR(150),
230
 
  c2 CHAR(150),
231
 
  c3 CHAR(150),
 
103
  c1 CHAR(50),
 
104
  c2 CHAR(50),
 
105
  c3 CHAR(50),
232
106
  KEY(c1, c2, c3)
233
107
  ) ENGINE= MyISAM;
234
108
INSERT INTO t1 (c1, c2, c3) VALUES
238
112
  ('m', 'n', 'o'), ('n', 'o', 'p'), ('o', 'p', 'q'), ('p', 'q', 'r'),
239
113
  ('q', 'r', 's'), ('r', 's', 't'), ('s', 't', 'u'), ('t', 'u', 'v'),
240
114
  ('u', 'v', 'w'), ('v', 'w', 'x'), ('w', 'x', 'y'), ('x', 'y', 'z');
241
 
INSERT INTO t1 (c1, c2, c3) SELECT c1, c2, c3 from t1;
242
 
INSERT INTO t1 (c1, c2, c3) SELECT c1, c2, c3 from t1;
243
 
INSERT INTO t1 (c1, c2, c3) SELECT c1, c2, c3 from t1;
 
115
CREATE TABLE t2 AS SELECT * FROM t1;
 
116
INSERT INTO t1 (c1, c2, c3) SELECT c1, c2, c3 from t2;
 
117
INSERT INTO t1 (c1, c2, c3) SELECT c1, c2, c3 from t2;
 
118
INSERT INTO t1 (c1, c2, c3) SELECT c1, c2, c3 from t2;
244
119
CHECK TABLE t1;
245
 
SHOW VARIABLES LIKE 'key_cache_block_size';
246
 
SET GLOBAL key_cache_block_size= @bug28478_key_cache_block_size;
247
 
DROP TABLE t1;
248
 
 
249
 
# End of 4.1 tests
 
120
SHOW VARIABLES LIKE 'myisam_key_cache_block_size';
 
121
SET GLOBAL myisam_key_cache_block_size= @save_myisam_key_cache_block_size;
 
122
DROP TABLE t1,t2;
 
123
 
 
124
# Check division limit and age threshold
 
125
 
 
126
# Division Limit: Minimum 1, maximum 100
 
127
SET GLOBAL myisam_key_cache_division_limit= 0;
 
128
 
 
129
SELECT @@myisam_key_cache_division_limit;
 
130
 
 
131
SET GLOBAL myisam_key_cache_division_limit= 101;
 
132
 
 
133
SELECT @@myisam_key_cache_division_limit;
 
134
 
 
135
# Age Threshold: Minimum 100, maximum UINT32_MAX
 
136
SET GLOBAL myisam_key_cache_age_threshold= 98;
 
137
 
 
138
SELECT @@myisam_key_cache_age_threshold;
 
139
 
 
140
SET GLOBAL myisam_key_cache_age_threshold= 5000000000;
 
141
 
 
142
SELECT @@myisam_key_cache_age_threshold;