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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
|
drop table if exists t1;
show variables like 'version';
Variable_name Value
version ####.##.####
select version();
version()
####.##.####
select database();
database()
test
CREATE TABLE `t1` (
`col_bigint` bigint,
`col_text` text,
`col_char` char (1),
`col_enum` enum ('a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'),
`col_int` int,
`col_char_not_null` char (1) not null,
`col_int_not_null_key` int not null,
`col_text_not_null` text not null,
`col_enum_not_null_key` enum ('a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z') not null,
`col_int_key` int,
`col_char_key` char (1),
`col_enum_not_null` enum ('a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z') not null,
`col_text_not_null_key` text not null,
pk integer auto_increment,
`col_bigint_key` bigint,
`col_int_not_null` int not null,
`col_bigint_not_null` bigint not null,
`col_bigint_not_null_key` bigint not null,
`col_char_not_null_key` char (1) not null,
`col_text_key` text,
`col_enum_key` enum ('a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'),
/*Indices*/
key (`col_int_not_null_key` ),
key (`col_enum_not_null_key` ),
key (`col_int_key` ),
key (`col_char_key` ),
key (`col_text_not_null_key` (255)),
primary key (pk),
key (`col_bigint_key` ),
key (`col_bigint_not_null_key` ),
key (`col_char_not_null_key` ),
key (`col_text_key` (255)),
key (`col_enum_key` )) ENGINE=innodb;
set AUTOCOMMIT=OFF;
select SQL_BIG_RESULT table_schema,
table_name,
CASE WHEN table_type = 'STANDARD' THEN 'table'
WHEN table_type = 'FUNCTION' then 'function'
ELSE 'misc' END,
column_name,
CASE WHEN IS_USED_IN_PRIMARY = 'YES' THEN 'primary'
WHEN IS_INDEXED = 'YES' THEN 'indexed'
ELSE 'indexed' END
FROM data_dictionary.tables INNER JOIN
data_dictionary.columns USING(table_schema, table_name) ORDER BY table_schema, table_name limit 20;
table_schema table_name CASE WHEN table_type = 'STANDARD' THEN 'table'
WHEN table_type = 'FUNCTION' then 'function'
ELSE 'misc' END column_name CASE WHEN IS_USED_IN_PRIMARY = 'YES' THEN 'primary'
WHEN IS_INDEXED = 'YES' THEN 'indexed'
ELSE 'indexed' END
DATA_DICTIONARY CHARACTER_SETS function CHARACTER_SET_NAME indexed
DATA_DICTIONARY CHARACTER_SETS function DEFAULT_COLLATE_NAME indexed
DATA_DICTIONARY CHARACTER_SETS function DESCRIPTION indexed
DATA_DICTIONARY CHARACTER_SETS function MAXLEN indexed
DATA_DICTIONARY COLLATIONS function CHARACTER_SET_NAME indexed
DATA_DICTIONARY COLLATIONS function COLLATION_NAME indexed
DATA_DICTIONARY COLLATIONS function DESCRIPTION indexed
DATA_DICTIONARY COLLATIONS function ID indexed
DATA_DICTIONARY COLLATIONS function IS_DEFAULT indexed
DATA_DICTIONARY COLLATIONS function IS_COMPILED indexed
DATA_DICTIONARY COLLATIONS function SORTLEN indexed
DATA_DICTIONARY COLUMNS function TABLE_SCHEMA indexed
DATA_DICTIONARY COLUMNS function TABLE_NAME indexed
DATA_DICTIONARY COLUMNS function COLUMN_NAME indexed
DATA_DICTIONARY COLUMNS function COLUMN_TYPE indexed
DATA_DICTIONARY COLUMNS function ORDINAL_POSITION indexed
DATA_DICTIONARY COLUMNS function COLUMN_DEFAULT indexed
DATA_DICTIONARY COLUMNS function COLUMN_DEFAULT_IS_NULL indexed
DATA_DICTIONARY COLUMNS function COLUMN_DEFAULT_UPDATE indexed
DATA_DICTIONARY COLUMNS function IS_NULLABLE indexed
CREATE SCHEMA randgen_query_test;
USE randgen_query_test;
CREATE TABLE t1 (a INT);
CREATE TABLE t2 LIKE t1;
CREATE TABLE t3 LIKE t1;
CREATE TABLE t4 (b CHAR(500));
CREATE TABLE t5 LIKE t4;
select SQL_BIG_RESULT table_schema,
table_name,
CASE WHEN table_type = 'STANDARD' THEN 'table'
WHEN table_type = 'FUNCTION' then 'function'
ELSE 'misc' END,
column_name,
CASE WHEN IS_USED_IN_PRIMARY = 'YES' THEN 'primary'
WHEN IS_INDEXED = 'YES' THEN 'indexed'
ELSE 'indexed' END
FROM data_dictionary.tables INNER JOIN
data_dictionary.columns USING(table_schema, table_name) WHERE table_schema NOT IN ('DATA_DICTIONARY','INFORMATION_SCHEMA')
ORDER BY table_schema, table_name limit 20;
table_schema table_name CASE WHEN table_type = 'STANDARD' THEN 'table'
WHEN table_type = 'FUNCTION' then 'function'
ELSE 'misc' END column_name CASE WHEN IS_USED_IN_PRIMARY = 'YES' THEN 'primary'
WHEN IS_INDEXED = 'YES' THEN 'indexed'
ELSE 'indexed' END
randgen_query_test t1 table a indexed
randgen_query_test t2 table a indexed
randgen_query_test t3 table a indexed
randgen_query_test t4 table b indexed
randgen_query_test t5 table b indexed
test t1 table col_bigint indexed
test t1 table col_text indexed
test t1 table col_char indexed
test t1 table col_enum indexed
test t1 table col_int indexed
test t1 table col_char_not_null indexed
test t1 table col_int_not_null_key indexed
test t1 table col_text_not_null indexed
test t1 table col_enum_not_null_key indexed
test t1 table col_int_key indexed
test t1 table col_char_key indexed
test t1 table col_enum_not_null indexed
test t1 table col_text_not_null_key indexed
test t1 table pk primary
test t1 table col_bigint_key indexed
DROP SCHEMA randgen_query_test;
USE test;
select AVG(`col_int_key`) + AVG(`col_int`) AS average1,
(SUM(`col_int_key`) + SUM(`col_int`)) / COUNT(*) AS average2,
COUNT(*) AS count FROM t1;
average1 average2 count
NULL NULL 0
select collation_name,character_set_name FROM data_dictionary.collations;
collation_name character_set_name
binary binary
utf8_bin utf8_general_ci
utf8_czech_ci utf8_general_ci
utf8_danish_ci utf8_general_ci
utf8_esperanto_ci utf8_general_ci
utf8_estonian_ci utf8_general_ci
utf8_general_ci utf8_general_ci
utf8_hungarian_ci utf8_general_ci
utf8_icelandic_ci utf8_general_ci
utf8_latvian_ci utf8_general_ci
utf8_lithuanian_ci utf8_general_ci
utf8_persian_ci utf8_general_ci
utf8_polish_ci utf8_general_ci
utf8_roman_ci utf8_general_ci
utf8_romanian_ci utf8_general_ci
utf8_sinhala_ci utf8_general_ci
utf8_slovak_ci utf8_general_ci
utf8_slovenian_ci utf8_general_ci
utf8_spanish2_ci utf8_general_ci
utf8_spanish_ci utf8_general_ci
utf8_swedish_ci utf8_general_ci
utf8_turkish_ci utf8_general_ci
utf8_unicode_ci utf8_general_ci
select COUNT(*) from data_dictionary.tables;
COUNT(*)
####.##.####
DROP TABLE t1;
|