2
# Test of the MyISAM key cache
5
drop table if exists t1, t2, t3;
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;
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;
19
# Change default key cache size
20
SET @@global.myisam_key_cache_size=16*1024*1024;
22
# Drop Key Cache (warning generated)
23
SET @@global.myisam_key_cache_size=0;
25
SET @@global.myisam_key_cache_size=0;
27
# Change default key cache size
28
SET @@global.myisam_key_cache_size=16*1024*1024;
30
# Print key buffer with different syntaxes
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;
39
SET @@global.myisam_key_cache_size=@save_myisam_key_cache_size;
45
SELECT @@myisam_key_cache_size;
47
SELECT @@skr.storage_engine="test";
50
select @@keycache1.myisam_key_cache_block_size;
52
show status like 'key_blocks_used';
54
# Test to set up a too small size for a key cache (bug #2064)
55
set global myisam_key_cache_size=100;
58
# Bug #19079: corrupted index when myisam_key_cache_block_size is not multiple of
61
CREATE temporary TABLE t1(a int NOT NULL AUTO_INCREMENT PRIMARY KEY) ENGINE=MYISAM;
62
SET GLOBAL myisam_key_cache_block_size=1536;
63
INSERT INTO t1 VALUES (1);
64
SELECT @@myisam_key_cache_block_size;
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;
71
INSERT INTO t1 VALUES (1,0);
72
INSERT INTO t2(b) SELECT b FROM t1;
73
INSERT INTO t1(b) SELECT b FROM t2;
74
INSERT INTO t2(b) SELECT b FROM t1;
75
INSERT INTO t1(b) SELECT b FROM t2;
76
INSERT INTO t2(b) SELECT b FROM t1;
77
INSERT INTO t1(b) SELECT b FROM t2;
78
INSERT INTO t2(b) SELECT b FROM t1;
79
INSERT INTO t1(b) SELECT b FROM t2;
80
INSERT INTO t2(b) SELECT b FROM t1;
81
INSERT INTO t1(b) SELECT b FROM t2;
82
INSERT INTO t2(b) SELECT b FROM t1;
83
INSERT INTO t1(b) SELECT b FROM t2;
84
INSERT INTO t2(b) SELECT b FROM t1;
85
INSERT INTO t1(b) SELECT b FROM t2;
86
INSERT INTO t2(b) SELECT b FROM t1;
87
INSERT INTO t1(b) SELECT b FROM t2;
88
INSERT INTO t2(b) SELECT b FROM t1;
89
INSERT INTO t1(b) SELECT b FROM t2;
90
SELECT COUNT(*) FROM t1;
91
SELECT @@myisam_key_cache_block_size;
94
# Restore changed variables
95
set global myisam_key_cache_block_size= @save_myisam_key_cache_block_size;
98
# Bug#28478 - Improper myisam_key_cache_block_size corrupts MyISAM tables
100
SET GLOBAL myisam_key_cache_block_size= 1536;
101
CREATE TEMPORARY TABLE t1 (
102
id BIGINT NOT NULL AUTO_INCREMENT PRIMARY KEY,
108
INSERT INTO t1 (c1, c2, c3) VALUES
109
('a', 'b', 'c'), ('b', 'c', 'd'), ('c', 'd', 'e'), ('d', 'e', 'f'),
110
('e', 'f', 'g'), ('f', 'g', 'h'), ('g', 'h', 'i'), ('h', 'i', 'j'),
111
('i', 'j', 'k'), ('j', 'k', 'l'), ('k', 'l', 'm'), ('l', 'm', 'n'),
112
('m', 'n', 'o'), ('n', 'o', 'p'), ('o', 'p', 'q'), ('p', 'q', 'r'),
113
('q', 'r', 's'), ('r', 's', 't'), ('s', 't', 'u'), ('t', 'u', 'v'),
114
('u', 'v', 'w'), ('v', 'w', 'x'), ('w', 'x', 'y'), ('x', 'y', 'z');
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;
120
SHOW VARIABLES LIKE 'myisam_key_cache_block_size';
121
SET GLOBAL myisam_key_cache_block_size= @save_myisam_key_cache_block_size;
124
# Check division limit and age threshold
126
# Division Limit: Minimum 1, maximum 100
127
SET GLOBAL myisam_key_cache_division_limit= 0;
129
SELECT @@myisam_key_cache_division_limit;
131
SET GLOBAL myisam_key_cache_division_limit= 101;
133
SELECT @@myisam_key_cache_division_limit;
135
# Age Threshold: Minimum 100, maximum UINT32_MAX
136
SET GLOBAL myisam_key_cache_age_threshold= 98;
138
SELECT @@myisam_key_cache_age_threshold;
140
SET GLOBAL myisam_key_cache_age_threshold= 5000000000;
142
SELECT @@myisam_key_cache_age_threshold;