summaryrefslogtreecommitdiff
path: root/mysql-test/suite/sys_vars/t/innodb_stats_method_basic.test
blob: f01574c3683fe262c4b302ceb5d319a3d5e4ece0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
#
# 2011-08-05 - Added
#

--source include/have_innodb.inc

SET @start_global_value = @@global.innodb_stats_method;
SELECT @start_global_value;

#
# exists as global only 
#
--echo Valid values are 'nulls_equal', 'nulls_unequal', 'nulls_ignored'
SELECT @@global.innodb_stats_method in ('nulls_equal', 'nulls_unequal', 
'nulls_ignored');
SELECT @@global.innodb_stats_method;
--error ER_INCORRECT_GLOBAL_LOCAL_VAR
SELECT @@session.innodb_stats_method;
SHOW global variables LIKE 'innodb_stats_method';
SHOW session variables LIKE 'innodb_stats_method';
SELECT * FROM information_schema.global_variables 
WHERE variable_name='innodb_stats_method';
SELECT * FROM information_schema.session_variables 
WHERE variable_name='innodb_stats_method';

#
# show that it's writable
#
SET global innodb_stats_method='nulls_equal';
SELECT @@global.innodb_stats_method;
SELECT * FROM information_schema.global_variables 
WHERE variable_name='innodb_stats_method';
SELECT * FROM information_schema.session_variables 
WHERE variable_name='innodb_stats_method';
SET @@global.innodb_stats_method='nulls_unequal';
SELECT @@global.innodb_stats_method;
SELECT * FROM information_schema.global_variables 
WHERE variable_name='innodb_stats_method';
SELECT * FROM information_schema.session_variables 
WHERE variable_name='innodb_stats_method';
SET global innodb_stats_method=2;
SELECT @@global.innodb_stats_method;
SELECT * FROM information_schema.global_variables 
WHERE variable_name='innodb_stats_method';
SELECT * FROM information_schema.session_variables 
WHERE variable_name='innodb_stats_method';

--error ER_GLOBAL_VARIABLE
SET session innodb_stats_method='nulls_equal';
--error ER_GLOBAL_VARIABLE
SET @@session.innodb_stats_method='nulls_ignored';

#
# incorrect types
#
--error ER_WRONG_TYPE_FOR_VAR
SET global innodb_stats_method=1.1;
--error ER_WRONG_VALUE_FOR_VAR
SET global innodb_stats_method=4;
--error ER_WRONG_VALUE_FOR_VAR
SET global innodb_stats_method=-2;
--error ER_WRONG_TYPE_FOR_VAR
SET global innodb_stats_method=1e1;
--error ER_WRONG_VALUE_FOR_VAR
SET global innodb_stats_method='some';

#
# Cleanup
#

SET @@global.innodb_stats_method = @start_global_value;
SELECT @@global.innodb_stats_method;