added code covarage for functions convert(), nullif(), crc32(), is_used_lock(), char_lengtrh(), bit_xor()
added string length for more speed made code covarage for print() method of Item fixed printability of some items (SCRUM) (WL#1274)
This commit is contained in:
parent
ae380c5855
commit
33346e26af
@ -112,6 +112,11 @@ insert into t1 set i = null;
|
|||||||
select last_insert_id();
|
select last_insert_id();
|
||||||
last_insert_id()
|
last_insert_id()
|
||||||
255
|
255
|
||||||
|
explain extended select last_insert_id();
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority no_cache 255 AS `last_insert_id()`
|
||||||
insert into t1 set i = 254;
|
insert into t1 set i = 254;
|
||||||
ERROR 23000: Duplicate entry '254' for key 1
|
ERROR 23000: Duplicate entry '254' for key 1
|
||||||
select last_insert_id();
|
select last_insert_id();
|
||||||
|
@ -3,4 +3,9 @@ create table t1(n int not null, key(n)) delay_key_write = 1;
|
|||||||
select count(distinct n) from t1;
|
select count(distinct n) from t1;
|
||||||
count(distinct n)
|
count(distinct n)
|
||||||
100
|
100
|
||||||
|
explain extended select count(distinct n) from t1;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 index NULL n 4 NULL 200 Using index
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority count(distinct test.t1.n) AS `count(distinct n)` from test.t1
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
@ -23,6 +23,11 @@ false
|
|||||||
select CASE 1 when 1 then "one" WHEN 2 then "two" ELSE "more" END;
|
select CASE 1 when 1 then "one" WHEN 2 then "two" ELSE "more" END;
|
||||||
CASE 1 when 1 then "one" WHEN 2 then "two" ELSE "more" END
|
CASE 1 when 1 then "one" WHEN 2 then "two" ELSE "more" END
|
||||||
one
|
one
|
||||||
|
explain extended select CASE 1 when 1 then "one" WHEN 2 then "two" ELSE "more" END;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority (case 1 when 1 then _latin1'one' when 2 then _latin1'two' else _latin1'more' end) AS `CASE 1 when 1 then "one" WHEN 2 then "two" ELSE "more" END`
|
||||||
select CASE 2.0 when 1 then "one" WHEN 2.0 then "two" ELSE "more" END;
|
select CASE 2.0 when 1 then "one" WHEN 2.0 then "two" ELSE "more" END;
|
||||||
CASE 2.0 when 1 then "one" WHEN 2.0 then "two" ELSE "more" END
|
CASE 2.0 when 1 then "one" WHEN 2.0 then "two" ELSE "more" END
|
||||||
two
|
two
|
||||||
@ -57,6 +62,11 @@ fcase count(*)
|
|||||||
0 2
|
0 2
|
||||||
2 1
|
2 1
|
||||||
3 1
|
3 1
|
||||||
|
explain extended select case a when 1 then 2 when 2 then 3 else 0 end as fcase, count(*) from t1 group by fcase;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 ALL NULL NULL NULL NULL 4 Using temporary; Using filesort
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority (case test.t1.a when 1 then 2 when 2 then 3 else 0 end) AS `fcase`,count(0) AS `count(*)` from test.t1 group by (case test.t1.a when 1 then 2 when 2 then 3 else 0 end)
|
||||||
select case a when 1 then "one" when 2 then "two" else "nothing" end as fcase, count(*) from t1 group by fcase;
|
select case a when 1 then "one" when 2 then "two" else "nothing" end as fcase, count(*) from t1 group by fcase;
|
||||||
fcase count(*)
|
fcase count(*)
|
||||||
nothing 2
|
nothing 2
|
||||||
@ -122,6 +132,14 @@ CREATE TABLE t1 SELECT
|
|||||||
COALESCE(1), COALESCE(1.0),COALESCE('a'),
|
COALESCE(1), COALESCE(1.0),COALESCE('a'),
|
||||||
COALESCE(1,1.0), COALESCE(1,'1'),COALESCE(1.1,'1'),
|
COALESCE(1,1.0), COALESCE(1,'1'),COALESCE(1.1,'1'),
|
||||||
COALESCE('a' COLLATE latin1_bin,'b');
|
COALESCE('a' COLLATE latin1_bin,'b');
|
||||||
|
explain extended SELECT
|
||||||
|
COALESCE(1), COALESCE(1.0),COALESCE('a'),
|
||||||
|
COALESCE(1,1.0), COALESCE(1,'1'),COALESCE(1.1,'1'),
|
||||||
|
COALESCE('a' COLLATE latin1_bin,'b');
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority coalesce(1) AS `COALESCE(1)`,coalesce(1.0) AS `COALESCE(1.0)`,coalesce(_latin1'a') AS `COALESCE('a')`,coalesce(1,1.0) AS `COALESCE(1,1.0)`,coalesce(1,_latin1'1') AS `COALESCE(1,'1')`,coalesce(1.1,_latin1'1') AS `COALESCE(1.1,'1')`,coalesce((_latin1'a' collate _latin1'latin1_bin'),_latin1'b') AS `COALESCE('a' COLLATE latin1_bin,'b')`
|
||||||
SHOW CREATE TABLE t1;
|
SHOW CREATE TABLE t1;
|
||||||
Table Create Table
|
Table Create Table
|
||||||
t1 CREATE TABLE `t1` (
|
t1 CREATE TABLE `t1` (
|
||||||
|
@ -16,6 +16,11 @@ cast(-5 as unsigned) -1 cast(-5 as unsigned) + 1
|
|||||||
select ~5, cast(~5 as signed);
|
select ~5, cast(~5 as signed);
|
||||||
~5 cast(~5 as signed)
|
~5 cast(~5 as signed)
|
||||||
18446744073709551610 -6
|
18446744073709551610 -6
|
||||||
|
explain extended select ~5, cast(~5 as signed);
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority ~(5) AS `~5`,cast(~(5) as signed) AS `cast(~5 as signed)`
|
||||||
select cast(5 as unsigned) -6.0;
|
select cast(5 as unsigned) -6.0;
|
||||||
cast(5 as unsigned) -6.0
|
cast(5 as unsigned) -6.0
|
||||||
-1.0
|
-1.0
|
||||||
|
@ -521,6 +521,11 @@ character_set_client latin1
|
|||||||
SELECT charset('a'),collation('a'),coercibility('a'),'a'='A';
|
SELECT charset('a'),collation('a'),coercibility('a'),'a'='A';
|
||||||
charset('a') collation('a') coercibility('a') 'a'='A'
|
charset('a') collation('a') coercibility('a') 'a'='A'
|
||||||
latin1 latin1_swedish_ci 3 1
|
latin1 latin1_swedish_ci 3 1
|
||||||
|
explain extended SELECT charset('a'),collation('a'),coercibility('a'),'a'='A';
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority charset(_latin1'a') AS `charset('a')`,collation(_latin1'a') AS `collation('a')`,coercibility(_latin1'a') AS `coercibility('a')`,(_latin1'a' = _latin1'A') AS `'a'='A'`
|
||||||
SET CHARACTER SET koi8r;
|
SET CHARACTER SET koi8r;
|
||||||
SHOW VARIABLES LIKE 'collation_client';
|
SHOW VARIABLES LIKE 'collation_client';
|
||||||
Variable_name Value
|
Variable_name Value
|
||||||
|
@ -340,6 +340,129 @@ CYR CAPIT SOFT SIGN
|
|||||||
CYR CAPIT E ü ü
|
CYR CAPIT E ü ü
|
||||||
CYR CAPIT YU à à
|
CYR CAPIT YU à à
|
||||||
CYR CAPIT YA ñ ñ
|
CYR CAPIT YA ñ ñ
|
||||||
|
select CONVERT(koi8_ru_f, 'cp1251_general_ci', 'utf8_general_ci'), comment from t1;
|
||||||
|
CONVERT(koi8_ru_f, 'cp1251_general_ci', 'utf8_general_ci') comment
|
||||||
|
a LAT SMALL A
|
||||||
|
b LAT SMALL B
|
||||||
|
c LAT SMALL C
|
||||||
|
d LAT SMALL D
|
||||||
|
e LAT SMALL E
|
||||||
|
f LAT SMALL F
|
||||||
|
g LAT SMALL G
|
||||||
|
h LAT SMALL H
|
||||||
|
i LAT SMALL I
|
||||||
|
j LAT SMALL J
|
||||||
|
k LAT SMALL K
|
||||||
|
l LAT SMALL L
|
||||||
|
m LAT SMALL M
|
||||||
|
n LAT SMALL N
|
||||||
|
o LAT SMALL O
|
||||||
|
p LAT SMALL P
|
||||||
|
q LAT SMALL Q
|
||||||
|
r LAT SMALL R
|
||||||
|
s LAT SMALL S
|
||||||
|
t LAT SMALL T
|
||||||
|
u LAT SMALL U
|
||||||
|
v LAT SMALL V
|
||||||
|
w LAT SMALL W
|
||||||
|
x LAT SMALL X
|
||||||
|
y LAT SMALL Y
|
||||||
|
z LAT SMALL Z
|
||||||
|
A LAT CAPIT A
|
||||||
|
B LAT CAPIT B
|
||||||
|
C LAT CAPIT C
|
||||||
|
D LAT CAPIT D
|
||||||
|
E LAT CAPIT E
|
||||||
|
F LAT CAPIT F
|
||||||
|
G LAT CAPIT G
|
||||||
|
H LAT CAPIT H
|
||||||
|
I LAT CAPIT I
|
||||||
|
J LAT CAPIT J
|
||||||
|
K LAT CAPIT K
|
||||||
|
L LAT CAPIT L
|
||||||
|
M LAT CAPIT M
|
||||||
|
N LAT CAPIT N
|
||||||
|
O LAT CAPIT O
|
||||||
|
P LAT CAPIT P
|
||||||
|
Q LAT CAPIT Q
|
||||||
|
R LAT CAPIT R
|
||||||
|
S LAT CAPIT S
|
||||||
|
T LAT CAPIT T
|
||||||
|
U LAT CAPIT U
|
||||||
|
V LAT CAPIT V
|
||||||
|
W LAT CAPIT W
|
||||||
|
X LAT CAPIT X
|
||||||
|
Y LAT CAPIT Y
|
||||||
|
Z LAT CAPIT Z
|
||||||
|
â CYR SMALL A
|
||||||
|
÷ CYR SMALL BE
|
||||||
|
ţ CYR SMALL VE
|
||||||
|
ú CYR SMALL GE
|
||||||
|
ä CYR SMALL DE
|
||||||
|
ĺ CYR SMALL IE
|
||||||
|
? CYR SMALL IO
|
||||||
|
ă CYR SMALL ZHE
|
||||||
|
˙ CYR SMALL ZE
|
||||||
|
ę CYR SMALL I
|
||||||
|
ě CYR SMALL KA
|
||||||
|
í CYR SMALL EL
|
||||||
|
î CYR SMALL EM
|
||||||
|
ď CYR SMALL EN
|
||||||
|
đ CYR SMALL O
|
||||||
|
ň CYR SMALL PE
|
||||||
|
ô CYR SMALL ER
|
||||||
|
ő CYR SMALL ES
|
||||||
|
ć CYR SMALL TE
|
||||||
|
č CYR SMALL U
|
||||||
|
ö CYR SMALL EF
|
||||||
|
é CYR SMALL HA
|
||||||
|
ç CYR SMALL TSE
|
||||||
|
ŕ CYR SMALL CHE
|
||||||
|
ů CYR SMALL SHA
|
||||||
|
ü CYR SMALL SCHA
|
||||||
|
ń CYR SMALL HARD SIGN
|
||||||
|
ý CYR SMALL YERU
|
||||||
|
ű CYR SMALL SOFT SIGN
|
||||||
|
ř CYR SMALL E
|
||||||
|
á CYR SMALL YU
|
||||||
|
ó CYR SMALL YA
|
||||||
|
 CYR CAPIT A
|
||||||
|
× CYR CAPIT BE
|
||||||
|
Ţ CYR CAPIT VE
|
||||||
|
Ú CYR CAPIT GE
|
||||||
|
Ä CYR CAPIT DE
|
||||||
|
Ĺ CYR CAPIT IE
|
||||||
|
? CYR CAPIT IO
|
||||||
|
Ă CYR CAPIT ZHE
|
||||||
|
ß CYR CAPIT ZE
|
||||||
|
Ę CYR CAPIT I
|
||||||
|
Ě CYR CAPIT KA
|
||||||
|
Í CYR CAPIT EL
|
||||||
|
Î CYR CAPIT EM
|
||||||
|
Ď CYR CAPIT EN
|
||||||
|
Đ CYR CAPIT O
|
||||||
|
Ň CYR CAPIT PE
|
||||||
|
Ô CYR CAPIT ER
|
||||||
|
Ő CYR CAPIT ES
|
||||||
|
Ć CYR CAPIT TE
|
||||||
|
Č CYR CAPIT U
|
||||||
|
Ö CYR CAPIT EF
|
||||||
|
É CYR CAPIT HA
|
||||||
|
Ç CYR CAPIT TSE
|
||||||
|
Ŕ CYR CAPIT CHE
|
||||||
|
Ů CYR CAPIT SHA
|
||||||
|
Ü CYR CAPIT SCHA
|
||||||
|
Ń CYR CAPIT HARD SIGN
|
||||||
|
Ý CYR CAPIT YERU
|
||||||
|
Ű CYR CAPIT SOFT SIGN
|
||||||
|
Ř CYR CAPIT E
|
||||||
|
Á CYR CAPIT YU
|
||||||
|
Ó CYR CAPIT YA
|
||||||
|
explain extended select CONVERT(koi8_ru_f, 'cp1251_general_ci', 'utf8_general_ci'), comment from t1;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 ALL NULL NULL NULL NULL 116
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority convert(test.t1.koi8_ru_f,_latin1'utf8_general_ci',_latin1'cp1251_general_ci') AS `CONVERT(koi8_ru_f, 'cp1251_general_ci', 'utf8_general_ci')`,test.t1.comment AS `comment` from test.t1
|
||||||
ALTER TABLE t1 ADD bin_f CHAR(32) BYTE NOT NULL;
|
ALTER TABLE t1 ADD bin_f CHAR(32) BYTE NOT NULL;
|
||||||
UPDATE t1 SET bin_f=koi8_ru_f;
|
UPDATE t1 SET bin_f=koi8_ru_f;
|
||||||
SELECT COUNT(DISTINCT bin_f),COUNT(DISTINCT koi8_ru_f),COUNT(DISTINCT utf8_f) FROM t1;
|
SELECT COUNT(DISTINCT bin_f),COUNT(DISTINCT koi8_ru_f),COUNT(DISTINCT utf8_f) FROM t1;
|
||||||
|
@ -47,6 +47,9 @@ locate(_utf8 0xD091, _utf8 0xD0B0D0B1D0B2 collate utf8_bin)
|
|||||||
select locate(_utf8 0xD0B1, _utf8 0xD0B0D091D0B2 collate utf8_bin);
|
select locate(_utf8 0xD0B1, _utf8 0xD0B0D091D0B2 collate utf8_bin);
|
||||||
locate(_utf8 0xD0B1, _utf8 0xD0B0D091D0B2 collate utf8_bin)
|
locate(_utf8 0xD0B1, _utf8 0xD0B0D091D0B2 collate utf8_bin)
|
||||||
0
|
0
|
||||||
|
select length(_utf8 0xD0B1), bit_length(_utf8 0xD0B1), char_length(_utf8 0xD0B1);
|
||||||
|
length(_utf8 0xD0B1) bit_length(_utf8 0xD0B1) char_length(_utf8 0xD0B1)
|
||||||
|
2 16 1
|
||||||
select 'a' like 'a';
|
select 'a' like 'a';
|
||||||
'a' like 'a'
|
'a' like 'a'
|
||||||
1
|
1
|
||||||
|
@ -155,3 +155,8 @@ a
|
|||||||
select get_format(DATETIME, 'eur') as a;
|
select get_format(DATETIME, 'eur') as a;
|
||||||
a
|
a
|
||||||
%Y-%m-%d-%H.%i.%s
|
%Y-%m-%d-%H.%i.%s
|
||||||
|
explain extended select makedate(1997,1), addtime("31.12.97 11.59.59.999999 PM", "1 1.1.1.000002"),subtime("31.12.97 11.59.59.999999 PM", "1 1.1.1.000002"),timediff("01.01.97 11:59:59.000001 PM","31.12.95 11:59:59.000002 PM"),cast(str_to_date("15-01-2001 12:59:59", "%d-%m-%Y %H:%i:%S") as TIME), maketime(23,11,12),microsecond("1997-12-31 23:59:59.000001");
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority makedate(1997,1) AS `makedate(1997,1)`,addtime(_latin1'31.12.97 11.59.59.999999 PM',_latin1'31.12.97 11.59.59.999999 PM') AS `addtime("31.12.97 11.59.59.999999 PM", "1 1.1.1.000002")`,subtime(_latin1'31.12.97 11.59.59.999999 PM',_latin1'31.12.97 11.59.59.999999 PM') AS `subtime("31.12.97 11.59.59.999999 PM", "1 1.1.1.000002")`,timediff(_latin1'01.01.97 11:59:59.000001 PM',_latin1'31.12.95 11:59:59.000002 PM') AS `timediff("01.01.97 11:59:59.000001 PM","31.12.95 11:59:59.000002 PM")`,cast(str_to_date(_latin1'15-01-2001 12:59:59',_latin1'%d-%m-%Y %H:%i:%S') as time) AS `cast(str_to_date("15-01-2001 12:59:59", "%d-%m-%Y %H:%i:%S") as TIME)`,maketime(23,11,12) AS `maketime(23,11,12)`,microsecond(_latin1'1997-12-31 23:59:59.000001') AS `microsecond("1997-12-31 23:59:59.000001")`
|
||||||
|
@ -9,6 +9,11 @@ select * from t1 where MATCH(a,b) AGAINST ("collections");
|
|||||||
a b
|
a b
|
||||||
Only MyISAM tables support collections
|
Only MyISAM tables support collections
|
||||||
Full-text indexes are called collections
|
Full-text indexes are called collections
|
||||||
|
explain extended select * from t1 where MATCH(a,b) AGAINST ("collections");
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 fulltext a a 0 1 Using where
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority test.t1.a AS `a`,test.t1.b AS `b` from test.t1 where (match test.t1.a,test.t1.b against (_latin1'collections'))
|
||||||
select * from t1 where MATCH(a,b) AGAINST ("indexes");
|
select * from t1 where MATCH(a,b) AGAINST ("indexes");
|
||||||
a b
|
a b
|
||||||
Full-text indexes are called collections
|
Full-text indexes are called collections
|
||||||
@ -56,6 +61,11 @@ id select_type table type possible_keys key key_len ref rows Extra
|
|||||||
select * from t1 where MATCH(a,b) AGAINST("support -collections" IN BOOLEAN MODE);
|
select * from t1 where MATCH(a,b) AGAINST("support -collections" IN BOOLEAN MODE);
|
||||||
a b
|
a b
|
||||||
MySQL has now support for full-text search
|
MySQL has now support for full-text search
|
||||||
|
explain extended select * from t1 where MATCH(a,b) AGAINST("support -collections" IN BOOLEAN MODE);
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 fulltext a a 0 1 Using where
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority test.t1.a AS `a`,test.t1.b AS `b` from test.t1 where (match test.t1.a,test.t1.b against (_latin1'support -collections' in boolean mode))
|
||||||
select * from t1 where MATCH(a,b) AGAINST("support collections" IN BOOLEAN MODE);
|
select * from t1 where MATCH(a,b) AGAINST("support collections" IN BOOLEAN MODE);
|
||||||
a b
|
a b
|
||||||
MySQL has now support for full-text search
|
MySQL has now support for full-text search
|
||||||
|
@ -7,9 +7,19 @@ length(@test_compress_string)
|
|||||||
select uncompress(compress(@test_compress_string));
|
select uncompress(compress(@test_compress_string));
|
||||||
uncompress(compress(@test_compress_string))
|
uncompress(compress(@test_compress_string))
|
||||||
string for test compress function aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
|
string for test compress function aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
|
||||||
|
explain extended select uncompress(compress(@test_compress_string));
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority no_cache uncompress(compress((@test_compress_string))) AS `uncompress(compress(@test_compress_string))`
|
||||||
select uncompressed_length(compress(@test_compress_string))=length(@test_compress_string);
|
select uncompressed_length(compress(@test_compress_string))=length(@test_compress_string);
|
||||||
uncompressed_length(compress(@test_compress_string))=length(@test_compress_string)
|
uncompressed_length(compress(@test_compress_string))=length(@test_compress_string)
|
||||||
1
|
1
|
||||||
|
explain extended select uncompressed_length(compress(@test_compress_string))=length(@test_compress_string);
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority no_cache (uncompressed_length(compress((@test_compress_string))) = length((@test_compress_string))) AS `uncompressed_length(compress(@test_compress_string))=length(@test_compress_string)`
|
||||||
select uncompressed_length(compress(@test_compress_string));
|
select uncompressed_length(compress(@test_compress_string));
|
||||||
uncompressed_length(compress(@test_compress_string))
|
uncompressed_length(compress(@test_compress_string))
|
||||||
117
|
117
|
||||||
|
@ -14,6 +14,11 @@ grp group_concat(c)
|
|||||||
1 a
|
1 a
|
||||||
2 b,c
|
2 b,c
|
||||||
3 E,C,D,d,d,D
|
3 E,C,D,d,d,D
|
||||||
|
explain extended select grp,group_concat(c) from t1 group by grp;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 ALL NULL NULL NULL NULL 9 Using filesort
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority test.t1.grp AS `grp`,group_concat(test.t1.c seperator ',') AS `group_concat(c)` from test.t1 group by test.t1.grp
|
||||||
select grp,group_concat(a,c) from t1 group by grp;
|
select grp,group_concat(a,c) from t1 group by grp;
|
||||||
grp group_concat(a,c)
|
grp group_concat(a,c)
|
||||||
1 1a
|
1 1a
|
||||||
@ -79,6 +84,11 @@ grp group_concat(distinct c order by c desc)
|
|||||||
1 a
|
1 a
|
||||||
2 c,b
|
2 c,b
|
||||||
3 E,D,C
|
3 E,D,C
|
||||||
|
explain extended select grp,group_concat(distinct c order by c desc) from t1 group by grp;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 ALL NULL NULL NULL NULL 9 Using filesort
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority test.t1.grp AS `grp`,group_concat(distinct test.t1.c order by test.t1.c seperator ',') AS `group_concat(distinct c order by c desc)` from test.t1 group by test.t1.grp
|
||||||
select grp,group_concat(c order by c separator ",") from t1 group by grp;
|
select grp,group_concat(c order by c separator ",") from t1 group by grp;
|
||||||
grp group_concat(c order by c separator ",")
|
grp group_concat(c order by c separator ",")
|
||||||
1 a
|
1 a
|
||||||
@ -94,6 +104,11 @@ grp group_concat(distinct c order by c separator ",")
|
|||||||
1 a
|
1 a
|
||||||
2 b,c
|
2 b,c
|
||||||
3 C,D,E
|
3 C,D,E
|
||||||
|
explain extended select grp,group_concat(distinct c order by c separator ",") from t1 group by grp;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 ALL NULL NULL NULL NULL 9 Using filesort
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority test.t1.grp AS `grp`,group_concat(distinct test.t1.c order by test.t1.c seperator ',') AS `group_concat(distinct c order by c separator ",")` from test.t1 group by test.t1.grp
|
||||||
select grp,group_concat(distinct c order by c desc separator ",") from t1 group by grp;
|
select grp,group_concat(distinct c order by c desc separator ",") from t1 group by grp;
|
||||||
grp group_concat(distinct c order by c desc separator ",")
|
grp group_concat(distinct c order by c desc separator ",")
|
||||||
1 a
|
1 a
|
||||||
|
@ -597,11 +597,16 @@ a count(b) sum(b) avg(b) std(b) min(b) max(b) bit_and(b) bit_or(b)
|
|||||||
1 0 NULL NULL NULL NULL NULL 0 0
|
1 0 NULL NULL NULL NULL NULL 0 0
|
||||||
2 1 1 1.0000 0.0000 1 1 0 1
|
2 1 1 1.0000 0.0000 1 1 0 1
|
||||||
3 1 1 1.0000 0.0000 1 1 1 1
|
3 1 1 1.0000 0.0000 1 1 1 1
|
||||||
select SQL_BIG_RESULT a,count(b), sum(b), avg(b), std(b), min(b), max(b), bit_and(b), bit_or(b) from t1 group by a;
|
select SQL_BIG_RESULT a,count(b), sum(b), avg(b), std(b), min(b), max(b), bit_and(b), bit_or(b), bit_xor(b) from t1 group by a;
|
||||||
a count(b) sum(b) avg(b) std(b) min(b) max(b) bit_and(b) bit_or(b)
|
a count(b) sum(b) avg(b) std(b) min(b) max(b) bit_and(b) bit_or(b) bit_xor(b)
|
||||||
1 0 NULL NULL NULL NULL NULL 18446744073709551615 0
|
1 0 NULL NULL NULL NULL NULL 18446744073709551615 0 0
|
||||||
2 1 1 1.0000 0.0000 1 1 1 1
|
2 1 1 1.0000 0.0000 1 1 1 1 1
|
||||||
3 1 1 1.0000 0.0000 1 1 1 1
|
3 1 1 1.0000 0.0000 1 1 1 1 1
|
||||||
|
explain extended select SQL_BIG_RESULT a,count(b), sum(b), avg(b), std(b), min(b), max(b), bit_and(b), bit_or(b), bit_xor(b) from t1 group by a;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 ALL NULL NULL NULL NULL 5 Using filesort
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority big_result test.t1.a AS `a`,count(test.t1.b) AS `count(b)`,sum(test.t1.b) AS `sum(b)`,avg(test.t1.b) AS `avg(b)`,std(test.t1.b) AS `std(b)`,min(test.t1.b) AS `min(b)`,max(test.t1.b) AS `max(b)`,bit_and(test.t1.b) AS `bit_and(b)`,bit_or(test.t1.b) AS `bit_or(b)`,bit_xor(test.t1.b) AS `bit_xor(b)` from test.t1 group by test.t1.a
|
||||||
drop table t1;
|
drop table t1;
|
||||||
create table t1 (USR_ID integer not null, MAX_REQ integer not null, constraint PK_SEA_USER primary key (USR_ID)) type=InnoDB;
|
create table t1 (USR_ID integer not null, MAX_REQ integer not null, constraint PK_SEA_USER primary key (USR_ID)) type=InnoDB;
|
||||||
insert into t1 values (1, 3);
|
insert into t1 values (1, 3);
|
||||||
|
@ -39,6 +39,25 @@ a
|
|||||||
a
|
a
|
||||||
aa
|
aa
|
||||||
aaa
|
aaa
|
||||||
|
explain extended select if(u=1,st,binary st) s from t1 where st like "%a%" order by s;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 ALL NULL NULL NULL NULL 7 Using where; Using filesort
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority if((test.t1.u = 1),test.t1.st,(test.t1.st collate _latin1'BINARY')) AS `s` from test.t1 where (test.t1.st like _latin1'%a%') order by if((test.t1.u = 1),test.t1.st,(test.t1.st collate _latin1'BINARY'))
|
||||||
|
select nullif(u=0, 'test') from t1;
|
||||||
|
nullif(u=0, 'test')
|
||||||
|
NULL
|
||||||
|
NULL
|
||||||
|
NULL
|
||||||
|
NULL
|
||||||
|
NULL
|
||||||
|
1
|
||||||
|
1
|
||||||
|
explain extended select nullif(u=0, 'test') from t1;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 ALL NULL NULL NULL NULL 7
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority nullif((test.t1.u = 0),_latin1'test') AS `nullif(u=0, 'test')` from test.t1
|
||||||
drop table t1;
|
drop table t1;
|
||||||
create table t1 (num double(12,2));
|
create table t1 (num double(12,2));
|
||||||
insert into t1 values (144.54);
|
insert into t1 values (144.54);
|
||||||
|
@ -142,6 +142,11 @@ a c c
|
|||||||
select * from t1 where 'a' in (a,b,c collate latin1_bin);
|
select * from t1 where 'a' in (a,b,c collate latin1_bin);
|
||||||
a b c
|
a b c
|
||||||
a c c
|
a c c
|
||||||
|
explain extended select * from t1 where 'a' in (a,b,c collate latin1_bin);
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 ALL NULL NULL NULL NULL 2 Using where
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority test.t1.a AS `a`,test.t1.b AS `b`,test.t1.c AS `c` from test.t1 where (_latin1'a' IN (test.t1.a,test.t1.b,(test.t1.c collate _latin1'latin1_bin')))
|
||||||
drop table t1;
|
drop table t1;
|
||||||
select '1.0' in (1,2);
|
select '1.0' in (1,2);
|
||||||
'1.0' in (1,2)
|
'1.0' in (1,2)
|
||||||
|
@ -16,6 +16,11 @@ round(5.64,1) round(5.64,2) round(5.64,-1) round(5.64,-2)
|
|||||||
select abs(-10), sign(-5), sign(5), sign(0);
|
select abs(-10), sign(-5), sign(5), sign(0);
|
||||||
abs(-10) sign(-5) sign(5) sign(0)
|
abs(-10) sign(-5) sign(5) sign(0)
|
||||||
10 -1 1 0
|
10 -1 1 0
|
||||||
|
explain extended select abs(-10), sign(-5), sign(5), sign(0);
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority abs(-(10)) AS `abs(-10)`,sign(-(5)) AS `sign(-5)`,sign(5) AS `sign(5)`,sign(0) AS `sign(0)`
|
||||||
select log(exp(10)),exp(log(sqrt(10))*2),log(-1),log(NULL),log(1,1),log(3,9),log(-1,2),log(NULL,2);
|
select log(exp(10)),exp(log(sqrt(10))*2),log(-1),log(NULL),log(1,1),log(3,9),log(-1,2),log(NULL,2);
|
||||||
log(exp(10)) exp(log(sqrt(10))*2) log(-1) log(NULL) log(1,1) log(3,9) log(-1,2) log(NULL,2)
|
log(exp(10)) exp(log(sqrt(10))*2) log(-1) log(NULL) log(1,1) log(3,9) log(-1,2) log(NULL,2)
|
||||||
10.000000 10.000000 NULL NULL NULL 2.000000 NULL NULL
|
10.000000 10.000000 NULL NULL NULL 2.000000 NULL NULL
|
||||||
|
@ -1,9 +1,19 @@
|
|||||||
select 1+1,1-1,1+1*2,8/5,8%5,mod(8,5),mod(8,5)|0,-(1+1)*-2;
|
select 1+1,1-1,1+1*2,8/5,8%5,mod(8,5),mod(8,5)|0,-(1+1)*-2;
|
||||||
1+1 1-1 1+1*2 8/5 8%5 mod(8,5) mod(8,5)|0 -(1+1)*-2
|
1+1 1-1 1+1*2 8/5 8%5 mod(8,5) mod(8,5)|0 -(1+1)*-2
|
||||||
2 0 3 1.60 3 3 3 4
|
2 0 3 1.60 3 3 3 4
|
||||||
|
explain extended select 1+1,1-1,1+1*2,8/5,8%5,mod(8,5),mod(8,5)|0,-(1+1)*-2;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority (1 + 1) AS `1+1`,(1 - 1) AS `1-1`,(1 + (1 * 2)) AS `1+1*2`,(8 / 5) AS `8/5`,(8 % 5) AS `8%5`,(8 % 5) AS `mod(8,5)`,((8 % 5) | 0) AS `mod(8,5)|0`,(-((1 + 1)) * -(2)) AS `-(1+1)*-2`
|
||||||
select 1 | (1+1),5 & 3,bit_count(7) ;
|
select 1 | (1+1),5 & 3,bit_count(7) ;
|
||||||
1 | (1+1) 5 & 3 bit_count(7)
|
1 | (1+1) 5 & 3 bit_count(7)
|
||||||
3 1 3
|
3 1 3
|
||||||
|
explain extended select 1 | (1+1),5 & 3,bit_count(7) ;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority (1 | (1 + 1)) AS `1 | (1+1)`,(5 & 3) AS `5 & 3`,bit_count(7) AS `bit_count(7)`
|
||||||
select 1 << 32,1 << 63, 1 << 64, 4 >> 2, 4 >> 63, 1<< 63 >> 60;
|
select 1 << 32,1 << 63, 1 << 64, 4 >> 2, 4 >> 63, 1<< 63 >> 60;
|
||||||
1 << 32 1 << 63 1 << 64 4 >> 2 4 >> 63 1<< 63 >> 60
|
1 << 32 1 << 63 1 << 64 4 >> 2 4 >> 63 1<< 63 >> 60
|
||||||
4294967296 9223372036854775808 0 1 0 8
|
4294967296 9223372036854775808 0 1 0 8
|
||||||
|
@ -36,6 +36,11 @@ insert into t1 (xxx) values('this is a test of some long text to see what happen
|
|||||||
select * from t1 where xxx regexp('is a test of some long text to');
|
select * from t1 where xxx regexp('is a test of some long text to');
|
||||||
xxx
|
xxx
|
||||||
this is a test of some long text to see what happens
|
this is a test of some long text to see what happens
|
||||||
|
explain extended select * from t1 where xxx regexp('is a test of some long text to');
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 system NULL NULL NULL NULL 1
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority test.t1.xxx AS `xxx` from test.t1 where (test.t1.xxx regexp _latin1'is a test of some long text to')
|
||||||
select * from t1 where xxx regexp('is a test of some long text to ');
|
select * from t1 where xxx regexp('is a test of some long text to ');
|
||||||
xxx
|
xxx
|
||||||
this is a test of some long text to see what happens
|
this is a test of some long text to see what happens
|
||||||
|
@ -1,6 +1,11 @@
|
|||||||
select interval(55,10,20,30,40,50,60,70,80,90,100),interval(3,1,1+1,1+1+1+1),field("IBM","NCA","ICL","SUN","IBM","DIGITAL"),field("A","B","C"),elt(2,"ONE","TWO","THREE"),interval(0,1,2,3,4),elt(1,1,2,3)|0,elt(1,1.1,1.2,1.3)+0;
|
select interval(55,10,20,30,40,50,60,70,80,90,100),interval(3,1,1+1,1+1+1+1),field("IBM","NCA","ICL","SUN","IBM","DIGITAL"),field("A","B","C"),elt(2,"ONE","TWO","THREE"),interval(0,1,2,3,4),elt(1,1,2,3)|0,elt(1,1.1,1.2,1.3)+0;
|
||||||
interval(55,10,20,30,40,50,60,70,80,90,100) interval(3,1,1+1,1+1+1+1) field("IBM","NCA","ICL","SUN","IBM","DIGITAL") field("A","B","C") elt(2,"ONE","TWO","THREE") interval(0,1,2,3,4) elt(1,1,2,3)|0 elt(1,1.1,1.2,1.3)+0
|
interval(55,10,20,30,40,50,60,70,80,90,100) interval(3,1,1+1,1+1+1+1) field("IBM","NCA","ICL","SUN","IBM","DIGITAL") field("A","B","C") elt(2,"ONE","TWO","THREE") interval(0,1,2,3,4) elt(1,1,2,3)|0 elt(1,1.1,1.2,1.3)+0
|
||||||
5 2 4 0 TWO 0 1 1.1
|
5 2 4 0 TWO 0 1 1.1
|
||||||
|
explain extended select INTERVAL(55,10,20,30,40,50,60,70,80,90,100),interval(3,1,1+1,1+1+1+1),field("IBM","NCA","ICL","SUN","IBM","DIGITAL"),field("A","B","C"),elt(2,"ONE","TWO","THREE"),interval(0,1,2,3,4),elt(1,1,2,3)|0,elt(1,1.1,1.2,1.3)+0;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority interval((55,10,20,30,40,50,60,70,80,90,100)) AS `INTERVAL(55,10,20,30,40,50,60,70,80,90,100)`,interval((3,1,(1 + 1),(((1 + 1) + 1) + 1))) AS `interval(3,1,1+1,1+1+1+1)`,field(_latin1'IBM',_latin1'NCA',_latin1'ICL',_latin1'SUN',_latin1'IBM',_latin1'DIGITAL') AS `field("IBM","NCA","ICL","SUN","IBM","DIGITAL")`,field(_latin1'A',_latin1'B',_latin1'C') AS `field("A","B","C")`,elt(2,_latin1'ONE',_latin1'TWO',_latin1'THREE') AS `elt(2,"ONE","TWO","THREE")`,interval((0,1,2,3,4)) AS `interval(0,1,2,3,4)`,(elt(1,1,2,3) | 0) AS `elt(1,1,2,3)|0`,(elt(1,1.1,1.2,1.3) + 0) AS `elt(1,1.1,1.2,1.3)+0`
|
||||||
select find_in_set("b","a,b,c"),find_in_set("c","a,b,c"),find_in_set("dd","a,bbb,dd"),find_in_set("bbb","a,bbb,dd");
|
select find_in_set("b","a,b,c"),find_in_set("c","a,b,c"),find_in_set("dd","a,bbb,dd"),find_in_set("bbb","a,bbb,dd");
|
||||||
find_in_set("b","a,b,c") find_in_set("c","a,b,c") find_in_set("dd","a,bbb,dd") find_in_set("bbb","a,bbb,dd")
|
find_in_set("b","a,b,c") find_in_set("c","a,b,c") find_in_set("dd","a,bbb,dd") find_in_set("bbb","a,bbb,dd")
|
||||||
2 3 3 2
|
2 3 3 2
|
||||||
|
@ -12,9 +12,15 @@ length('\n\t\r\b\0\_\%\\')
|
|||||||
select bit_length('\n\t\r\b\0\_\%\\');
|
select bit_length('\n\t\r\b\0\_\%\\');
|
||||||
bit_length('\n\t\r\b\0\_\%\\')
|
bit_length('\n\t\r\b\0\_\%\\')
|
||||||
80
|
80
|
||||||
select concat('monty',' was here ','again'),length('hello'),char(ascii('h'));
|
select char_length('\n\t\r\b\0\_\%\\');
|
||||||
concat('monty',' was here ','again') length('hello') char(ascii('h'))
|
char_length('\n\t\r\b\0\_\%\\')
|
||||||
monty was here again 5 h
|
10
|
||||||
|
select length(_latin1'\n\t\n\b\0\\_\\%\\');
|
||||||
|
length(_latin1'\n\t\n\b\0\\_\\%\\')
|
||||||
|
10
|
||||||
|
select concat('monty',' was here ','again'),length('hello'),char(ascii('h')),ord('h');
|
||||||
|
concat('monty',' was here ','again') length('hello') char(ascii('h')) ord('h')
|
||||||
|
monty was here again 5 h 104
|
||||||
select locate('he','hello'),locate('he','hello',2),locate('lo','hello',2) ;
|
select locate('he','hello'),locate('he','hello',2),locate('lo','hello',2) ;
|
||||||
locate('he','hello') locate('he','hello',2) locate('lo','hello',2)
|
locate('he','hello') locate('he','hello',2) locate('lo','hello',2)
|
||||||
1 0 4
|
1 0 4
|
||||||
@ -99,6 +105,9 @@ NULL
|
|||||||
select md5('hello');
|
select md5('hello');
|
||||||
md5('hello')
|
md5('hello')
|
||||||
5d41402abc4b2a76b9719d911017c592
|
5d41402abc4b2a76b9719d911017c592
|
||||||
|
select crc32("123");
|
||||||
|
crc32("123")
|
||||||
|
2286445522
|
||||||
select sha('abc');
|
select sha('abc');
|
||||||
sha('abc')
|
sha('abc')
|
||||||
a9993e364706816aba3e25717850c26c9cd0d89d
|
a9993e364706816aba3e25717850c26c9cd0d89d
|
||||||
@ -579,3 +588,8 @@ CONCAT("</a>",RPAD("",(55 - LENGTH(title)),"."))
|
|||||||
NULL
|
NULL
|
||||||
</a>..........................
|
</a>..........................
|
||||||
DROP TABLE t1;
|
DROP TABLE t1;
|
||||||
|
explain extended select md5('hello'), sha('abc'), sha1('abc'), soundex(''), 'mood' sounds like 'mud', aes_decrypt(aes_encrypt('abc','1'),'1'),concat('*',space(5),'*'), reverse('abc'), rpad('a',4,'1'), lpad('a',4,'1'), concat_ws(',','',NULL,'a'),make_set(255,_latin2'a',_latin2'b',_latin2'c'),elt(2,1),locate("a","b",2),format(130,10),char(0),conv(130,16,10),hex(130),binary 'HE', export_set(255,_latin2'y',_latin2'n',_latin2' '),FIELD('b' COLLATE latin1_bin,'A','B'),FIND_IN_SET(_latin1'B',_latin1'a,b,c,d'),collation(conv(130,16,10)), coercibility(conv(130,16,10)),length('\n\t\r\b\0\_\%\\'),bit_length('\n\t\r\b\0\_\%\\'),bit_length('\n\t\r\b\0\_\%\\'),concat('monty',' was here ','again'),length('hello'),char(ascii('h')),ord('h'),quote(1/0),crc32("123");
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority md5(_latin1'hello') AS `md5('hello')`,sha(_latin1'abc') AS `sha('abc')`,sha(_latin1'abc') AS `sha1('abc')`,soundex(_latin1'') AS `soundex('')`,(soundex(_latin1'mood') = soundex(_latin1'mud')) AS `'mood' sounds like 'mud'`,aes_decrypt(aes_encrypt(_latin1'abc',_latin1'1'),_latin1'1') AS `aes_decrypt(aes_encrypt('abc','1'),'1')`,concat(_latin1'*',repeat(_latin1' ',5),_latin1'*') AS `concat('*',space(5),'*')`,reverse(_latin1'abc') AS `reverse('abc')`,rpad(_latin1'a',4,_latin1'1') AS `rpad('a',4,'1')`,lpad(_latin1'a',4,_latin1'1') AS `lpad('a',4,'1')`,concat_ws(_latin1',',_latin1'',NULL,_latin1'a') AS `concat_ws(',','',NULL,'a')`,make_set(255,_latin2'a',_latin2'b',_latin2'c') AS `make_set(255,_latin2'a',_latin2'b',_latin2'c')`,elt(2,1) AS `elt(2,1)`,locate(_latin1'a',_latin1'b',2) AS `locate("a","b",2)`,format(130,10) AS `format(130,10)`,char(0) AS `char(0)`,conv(130,16,10) AS `conv(130,16,10)`,hex(130) AS `hex(130)`,(_latin1'HE' collate _latin1'BINARY') AS `binary 'HE'`,export_set(255,_latin2'y',_latin2'n',_latin2' ') AS `export_set(255,_latin2'y',_latin2'n',_latin2' ')`,field((_latin1'b' collate _latin1'latin1_bin'),_latin1'A',_latin1'B') AS `FIELD('b' COLLATE latin1_bin,'A','B')`,find_in_set(_latin1'B',_latin1'a,b,c,d') AS `FIND_IN_SET(_latin1'B',_latin1'a,b,c,d')`,collation(conv(130,16,10)) AS `collation(conv(130,16,10))`,coercibility(conv(130,16,10)) AS `coercibility(conv(130,16,10))`,length(_latin1'\n\t\r\b\0\\_\\%\\') AS `length('\n\t\r\b\0\_\%\\')`,bit_length(_latin1'\n\t\r\b\0\\_\\%\\') AS `bit_length('\n\t\r\b\0\_\%\\')`,bit_length(_latin1'\n\t\r\b\0\\_\\%\\') AS `bit_length('\n\t\r\b\0\_\%\\')`,concat(_latin1'monty',_latin1' was here ',_latin1'again') AS `concat('monty',' was here ','again')`,length(_latin1'hello') AS `length('hello')`,char(ascii(_latin1'h')) AS `char(ascii('h'))`,ord(_latin1'h') AS `ord('h')`,quote((1 / 0)) AS `quote(1/0)`,crc32(_latin1'123') AS `crc32("123")`
|
||||||
|
@ -37,6 +37,11 @@ version()>=_latin1"3.23.29"
|
|||||||
select charset(version());
|
select charset(version());
|
||||||
charset(version())
|
charset(version())
|
||||||
utf8
|
utf8
|
||||||
|
explain extended select database(), user();
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority no_cache database() AS `database()`,user() AS `user()`
|
||||||
create table t1 (version char(40)) select database(), user(), version() as 'version';
|
create table t1 (version char(40)) select database(), user(), version() as 'version';
|
||||||
show create table t1;
|
show create table t1;
|
||||||
Table Create Table
|
Table Create Table
|
||||||
|
@ -44,19 +44,47 @@ select -1.49 or -1.49,0.6 or 0.6;
|
|||||||
select 3 ^ 11, 1 ^ 1, 1 ^ 0, 1 ^ NULL, NULL ^ 1;
|
select 3 ^ 11, 1 ^ 1, 1 ^ 0, 1 ^ NULL, NULL ^ 1;
|
||||||
3 ^ 11 1 ^ 1 1 ^ 0 1 ^ NULL NULL ^ 1
|
3 ^ 11 1 ^ 1 1 ^ 0 1 ^ NULL NULL ^ 1
|
||||||
8 0 1 NULL NULL
|
8 0 1 NULL NULL
|
||||||
|
explain extended select 3 ^ 11, 1 ^ 1, 1 ^ 0, 1 ^ NULL, NULL ^ 1;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority (3 ^ 11) AS `3 ^ 11`,(1 ^ 1) AS `1 ^ 1`,(1 ^ 0) AS `1 ^ 0`,(1 ^ NULL) AS `1 ^ NULL`,(NULL ^ 1) AS `NULL ^ 1`
|
||||||
select 1 XOR 1, 1 XOR 0, 0 XOR 1, 0 XOR 0, NULL XOR 1, 1 XOR NULL, 0 XOR NULL;
|
select 1 XOR 1, 1 XOR 0, 0 XOR 1, 0 XOR 0, NULL XOR 1, 1 XOR NULL, 0 XOR NULL;
|
||||||
1 XOR 1 1 XOR 0 0 XOR 1 0 XOR 0 NULL XOR 1 1 XOR NULL 0 XOR NULL
|
1 XOR 1 1 XOR 0 0 XOR 1 0 XOR 0 NULL XOR 1 1 XOR NULL 0 XOR NULL
|
||||||
0 1 1 0 NULL NULL NULL
|
0 1 1 0 NULL NULL NULL
|
||||||
select 10 % 7, 10 mod 7, 10 div 3;
|
select 10 % 7, 10 mod 7, 10 div 3;
|
||||||
10 % 7 10 mod 7 10 div 3
|
10 % 7 10 mod 7 10 div 3
|
||||||
3 3 3
|
3 3 3
|
||||||
|
explain extended select 10 % 7, 10 mod 7, 10 div 3;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority (10 % 7) AS `10 % 7`,(10 % 7) AS `10 mod 7`,(10 DIV 3) AS `10 div 3`
|
||||||
select (1 << 64)-1, ((1 << 64)-1) DIV 1, ((1 << 64)-1) DIV 2;
|
select (1 << 64)-1, ((1 << 64)-1) DIV 1, ((1 << 64)-1) DIV 2;
|
||||||
(1 << 64)-1 ((1 << 64)-1) DIV 1 ((1 << 64)-1) DIV 2
|
(1 << 64)-1 ((1 << 64)-1) DIV 1 ((1 << 64)-1) DIV 2
|
||||||
18446744073709551615 18446744073709551615 9223372036854775807
|
18446744073709551615 18446744073709551615 9223372036854775807
|
||||||
|
explain extended select (1 << 64)-1, ((1 << 64)-1) DIV 1, ((1 << 64)-1) DIV 2;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority ((1 << 64) - 1) AS `(1 << 64)-1`,(((1 << 64) - 1) DIV 1) AS `((1 << 64)-1) DIV 1`,(((1 << 64) - 1) DIV 2) AS `((1 << 64)-1) DIV 2`
|
||||||
create table t1 (a int);
|
create table t1 (a int);
|
||||||
insert t1 values (1);
|
insert t1 values (1);
|
||||||
select * from t1 where 1 xor 1;
|
select * from t1 where 1 xor 1;
|
||||||
a
|
a
|
||||||
|
explain extended select * from t1 where 1 xor 1;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL Impossible WHERE noticed after reading const tables
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority test.t1.a AS `a` from test.t1 where (1 xor 1)
|
||||||
|
select - a from t1;
|
||||||
|
- a
|
||||||
|
-1
|
||||||
|
explain extended select - a from t1;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 system NULL NULL NULL NULL 1
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority -(test.t1.a) AS `- a` from test.t1
|
||||||
drop table t1;
|
drop table t1;
|
||||||
select 5 between 0 and 10 between 0 and 1,(5 between 0 and 10) between 0 and 1;
|
select 5 between 0 and 10 between 0 and 1,(5 between 0 and 10) between 0 and 1;
|
||||||
5 between 0 and 10 between 0 and 1 (5 between 0 and 10) between 0 and 1
|
5 between 0 and 10 between 0 and 1 (5 between 0 and 10) between 0 and 1
|
||||||
@ -73,6 +101,11 @@ _koi8r'a' = _koi8r'A'
|
|||||||
select _koi8r'a' = _koi8r'A' COLLATE koi8r_general_ci;
|
select _koi8r'a' = _koi8r'A' COLLATE koi8r_general_ci;
|
||||||
_koi8r'a' = _koi8r'A' COLLATE koi8r_general_ci
|
_koi8r'a' = _koi8r'A' COLLATE koi8r_general_ci
|
||||||
1
|
1
|
||||||
|
explain extended select _koi8r'a' = _koi8r'A' COLLATE koi8r_general_ci;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority (_koi8r'a' = (_koi8r'A' collate _latin1'koi8r_general_ci')) AS `_koi8r'a' = _koi8r'A' COLLATE koi8r_general_ci`
|
||||||
select _koi8r'a' = _koi8r'A' COLLATE koi8r_bin;
|
select _koi8r'a' = _koi8r'A' COLLATE koi8r_bin;
|
||||||
_koi8r'a' = _koi8r'A' COLLATE koi8r_bin
|
_koi8r'a' = _koi8r'A' COLLATE koi8r_bin
|
||||||
0
|
0
|
||||||
|
@ -486,3 +486,8 @@ strcmp(date_format(utc_timestamp(),"%Y-%m-%d"), utc_date())=0
|
|||||||
select strcmp(concat(utc_date(),' ',utc_time()),utc_timestamp())=0;
|
select strcmp(concat(utc_date(),' ',utc_time()),utc_timestamp())=0;
|
||||||
strcmp(concat(utc_date(),' ',utc_time()),utc_timestamp())=0
|
strcmp(concat(utc_date(),' ',utc_time()),utc_timestamp())=0
|
||||||
1
|
1
|
||||||
|
explain extended select period_add("9602",-12),period_diff(199505,"9404"),from_days(to_days("960101")),dayofmonth("1997-01-02"), month("1997-01-02"), monthname("1972-03-04"),dayofyear("0000-00-00"),HOUR("1997-03-03 23:03:22"),MINUTE("23:03:22"),SECOND(230322),QUARTER(980303),WEEK("1998-03-03"),yearweek("2000-01-01",1),week(19950101,1),year("98-02-03"),weekday(curdate())-weekday(now()),dayname("1962-03-03"),unix_timestamp(),sec_to_time(time_to_sec("0:30:47")/6.21),curtime(),utc_time(),curdate(),utc_date(),utc_timestamp(),date_format("1997-01-02 03:04:05", "%M %W %D %Y %y %m %d %h %i %s %w"),from_unixtime(unix_timestamp("1994-03-02 10:11:12")),"1997-12-31 23:59:59" + INTERVAL 1 SECOND,"1998-01-01 00:00:00" - INTERVAL 1 SECOND,INTERVAL 1 DAY + "1997-12-31", extract(YEAR FROM "1999-01-02 10:11:12"),date_add("1997-12-31 23:59:59",INTERVAL 1 SECOND);
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority no_cache period_add(_latin1'9602',-(12)) AS `period_add("9602",-12)`,period_diff(199505,_latin1'9404') AS `period_diff(199505,"9404")`,from_days(to_days(_latin1'960101')) AS `from_days(to_days("960101"))`,dayofmonth(_latin1'1997-01-02') AS `dayofmonth("1997-01-02")`,month(_latin1'1997-01-02') AS `month("1997-01-02")`,monthname(_latin1'1972-03-04') AS `monthname("1972-03-04")`,dayofyear(_latin1'0000-00-00') AS `dayofyear("0000-00-00")`,hour(_latin1'1997-03-03 23:03:22') AS `HOUR("1997-03-03 23:03:22")`,minute(_latin1'23:03:22') AS `MINUTE("23:03:22")`,second(230322) AS `SECOND(230322)`,quarter(980303) AS `QUARTER(980303)`,week(_latin1'1998-03-03',0) AS `WEEK("1998-03-03")`,yearweek(_latin1'2000-01-01',1) AS `yearweek("2000-01-01",1)`,week(19950101,1) AS `week(19950101,1)`,year(_latin1'98-02-03') AS `year("98-02-03")`,(weekday(to_days(curdate())) - weekday(to_days(now()))) AS `weekday(curdate())-weekday(now())`,dayname(to_days(_latin1'1962-03-03')) AS `dayname("1962-03-03")`,unix_timestamp() AS `unix_timestamp()`,sec_to_time((time_to_sec(_latin1'0:30:47') / 6.21)) AS `sec_to_time(time_to_sec("0:30:47")/6.21)`,curtime() AS `curtime()`,utc_time() AS `utc_time()`,curdate() AS `curdate()`,utc_date() AS `utc_date()`,utc_timestamp() AS `utc_timestamp()`,date_format(_latin1'1997-01-02 03:04:05',_latin1'%M %W %D %Y %y %m %d %h %i %s %w') AS `date_format("1997-01-02 03:04:05", "%M %W %D %Y %y %m %d %h %i %s %w")`,from_unixtime(unix_timestamp(_latin1'1994-03-02 10:11:12')) AS `from_unixtime(unix_timestamp("1994-03-02 10:11:12"))`,(_latin1'1997-12-31 23:59:59' + interval 1 second) AS `"1997-12-31 23:59:59" + INTERVAL 1 SECOND`,(_latin1'1998-01-01 00:00:00' - interval 1 second) AS `"1998-01-01 00:00:00" - INTERVAL 1 SECOND`,(_latin1'1997-12-31' + interval 1 day) AS `INTERVAL 1 DAY + "1997-12-31"`,extract(year from _latin1'1999-01-02 10:11:12') AS `extract(YEAR FROM "1999-01-02 10:11:12")`,(_latin1'1997-12-31 23:59:59' + interval 1 second) AS `date_add("1997-12-31 23:59:59",INTERVAL 1 SECOND)`
|
||||||
|
@ -284,9 +284,11 @@ select spid,count(*) from t1 where spid between 1 and 2 group by spid desc;
|
|||||||
spid count(*)
|
spid count(*)
|
||||||
2 2
|
2 2
|
||||||
1 1
|
1 1
|
||||||
explain select sql_big_result spid,sum(userid) from t1 group by spid desc;
|
explain extended select sql_big_result spid,sum(userid) from t1 group by spid desc;
|
||||||
id select_type table type possible_keys key key_len ref rows Extra
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
1 SIMPLE t1 ALL NULL NULL NULL NULL 8 Using filesort
|
1 SIMPLE t1 ALL NULL NULL NULL NULL 8 Using filesort
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority big_result test.t1.spID AS `spid`,sum(test.t1.userID) AS `sum(userid)` from test.t1 group by test.t1.spID desc
|
||||||
explain select sql_big_result spid,sum(userid) from t1 group by spid desc order by null;
|
explain select sql_big_result spid,sum(userid) from t1 group by spid desc order by null;
|
||||||
id select_type table type possible_keys key key_len ref rows Extra
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
1 SIMPLE t1 ALL NULL NULL NULL NULL 8
|
1 SIMPLE t1 ALL NULL NULL NULL NULL 8
|
||||||
|
@ -8,6 +8,11 @@ b
|
|||||||
select count(a) as b from t1 where a=0 having b >=0;
|
select count(a) as b from t1 where a=0 having b >=0;
|
||||||
b
|
b
|
||||||
0
|
0
|
||||||
|
explain extended select count(a) as b from t1 where a=0 having b >=0;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL Impossible WHERE noticed after reading const tables
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority count(test.t1.a) AS `b` from test.t1 where (test.t1.a = 0) having (count(test.t1.a) >= 0)
|
||||||
drop table t1;
|
drop table t1;
|
||||||
CREATE TABLE t1 (
|
CREATE TABLE t1 (
|
||||||
raw_id int(10) NOT NULL default '0',
|
raw_id int(10) NOT NULL default '0',
|
||||||
|
@ -56,4 +56,14 @@ a b c VALUES(a)
|
|||||||
5 0 30 NULL
|
5 0 30 NULL
|
||||||
8 9 60 NULL
|
8 9 60 NULL
|
||||||
2 1 11 NULL
|
2 1 11 NULL
|
||||||
|
explain extended SELECT *, VALUES(a) FROM t1;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 ALL NULL NULL NULL NULL 5
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority test.t1.a AS `a`,test.t1.b AS `b`,test.t1.c AS `c`,values(test.t1.a) AS `VALUES(a)` from test.t1
|
||||||
|
explain extended select * from t1 where values(a);
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL Impossible WHERE
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority test.t1.a AS `a`,test.t1.b AS `b`,test.t1.c AS `c` from test.t1
|
||||||
DROP TABLE t1;
|
DROP TABLE t1;
|
||||||
|
@ -2,6 +2,11 @@ drop table if exists t1;
|
|||||||
select null,\N,isnull(null),isnull(1/0),isnull(1/0 = null),ifnull(null,1),ifnull(null,"TRUE"),ifnull("TRUE","ERROR"),1/0 is null,1 is not null;
|
select null,\N,isnull(null),isnull(1/0),isnull(1/0 = null),ifnull(null,1),ifnull(null,"TRUE"),ifnull("TRUE","ERROR"),1/0 is null,1 is not null;
|
||||||
NULL NULL isnull(null) isnull(1/0) isnull(1/0 = null) ifnull(null,1) ifnull(null,"TRUE") ifnull("TRUE","ERROR") 1/0 is null 1 is not null
|
NULL NULL isnull(null) isnull(1/0) isnull(1/0 = null) ifnull(null,1) ifnull(null,"TRUE") ifnull("TRUE","ERROR") 1/0 is null 1 is not null
|
||||||
NULL NULL 1 1 1 1 TRUE TRUE 1 1
|
NULL NULL 1 1 1 1 TRUE TRUE 1 1
|
||||||
|
explain extended select null,\N,isnull(null),isnull(1/0),isnull(1/0 = null),ifnull(null,1),ifnull(null,"TRUE"),ifnull("TRUE","ERROR"),1/0 is null,1 is not null;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority NULL AS `NULL`,NULL AS `NULL`,isnull(NULL) AS `isnull(null)`,isnull((1 / 0)) AS `isnull(1/0)`,isnull(((1 / 0) = NULL)) AS `isnull(1/0 = null)`,ifnull(NULL,1) AS `ifnull(null,1)`,ifnull(NULL,_latin1'TRUE') AS `ifnull(null,"TRUE")`,ifnull(_latin1'TRUE',_latin1'ERROR') AS `ifnull("TRUE","ERROR")`,isnull((1 / 0)) AS `1/0 is null`,(1 is not null) AS `1 is not null`
|
||||||
select 1 | NULL,1 & NULL,1+NULL,1-NULL;
|
select 1 | NULL,1 & NULL,1+NULL,1-NULL;
|
||||||
1 | NULL 1 & NULL 1+NULL 1-NULL
|
1 | NULL 1 & NULL 1+NULL 1-NULL
|
||||||
NULL NULL NULL NULL
|
NULL NULL NULL NULL
|
||||||
@ -23,6 +28,11 @@ field(NULL,"a","b","c")
|
|||||||
select 2 between null and 1,2 between 3 AND NULL,NULL between 1 and 2,2 between NULL and 3, 2 between 1 AND null;
|
select 2 between null and 1,2 between 3 AND NULL,NULL between 1 and 2,2 between NULL and 3, 2 between 1 AND null;
|
||||||
2 between null and 1 2 between 3 AND NULL NULL between 1 and 2 2 between NULL and 3 2 between 1 AND null
|
2 between null and 1 2 between 3 AND NULL NULL between 1 and 2 2 between NULL and 3 2 between 1 AND null
|
||||||
0 0 NULL NULL NULL
|
0 0 NULL NULL NULL
|
||||||
|
explain extended select 2 between null and 1,2 between 3 AND NULL,NULL between 1 and 2,2 between NULL and 3, 2 between 1 AND null;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority (2 between NULL and 1) AS `2 between null and 1`,(2 between 3 and NULL) AS `2 between 3 AND NULL`,(NULL between 1 and 2) AS `NULL between 1 and 2`,(2 between NULL and 3) AS `2 between NULL and 3`,(2 between 1 and NULL) AS `2 between 1 AND null`
|
||||||
SELECT NULL AND NULL, 1 AND NULL, NULL AND 1, NULL OR NULL, 0 OR NULL, NULL OR 0;
|
SELECT NULL AND NULL, 1 AND NULL, NULL AND 1, NULL OR NULL, 0 OR NULL, NULL OR 0;
|
||||||
NULL AND NULL 1 AND NULL NULL AND 1 NULL OR NULL 0 OR NULL NULL OR 0
|
NULL AND NULL 1 AND NULL NULL AND 1 NULL OR NULL 0 OR NULL NULL OR 0
|
||||||
NULL NULL NULL NULL NULL NULL
|
NULL NULL NULL NULL NULL NULL
|
||||||
@ -35,6 +45,11 @@ NULL AND 0 0 and NULL
|
|||||||
select inet_ntoa(null),inet_aton(null),inet_aton("122.256"),inet_aton("122.226."),inet_aton("");
|
select inet_ntoa(null),inet_aton(null),inet_aton("122.256"),inet_aton("122.226."),inet_aton("");
|
||||||
inet_ntoa(null) inet_aton(null) inet_aton("122.256") inet_aton("122.226.") inet_aton("")
|
inet_ntoa(null) inet_aton(null) inet_aton("122.256") inet_aton("122.226.") inet_aton("")
|
||||||
NULL NULL NULL NULL NULL
|
NULL NULL NULL NULL NULL
|
||||||
|
explain extended select inet_ntoa(null),inet_aton(null),inet_aton("122.256"),inet_aton("122.226."),inet_aton("");
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority inet_ntoa(NULL) AS `inet_ntoa(null)`,inet_aton(NULL) AS `inet_aton(null)`,inet_aton(_latin1'122.256') AS `inet_aton("122.256")`,inet_aton(_latin1'122.226.') AS `inet_aton("122.226.")`,inet_aton(_latin1'') AS `inet_aton("")`
|
||||||
create table t1 (x int);
|
create table t1 (x int);
|
||||||
insert into t1 values (null);
|
insert into t1 values (null);
|
||||||
select * from t1 where x != 0;
|
select * from t1 where x != 0;
|
||||||
|
@ -81,9 +81,11 @@ TV 2 2000 200
|
|||||||
TV 2 NULL 200
|
TV 2 NULL 200
|
||||||
TV NULL NULL 600
|
TV NULL NULL 600
|
||||||
NULL NULL NULL 7785
|
NULL NULL NULL 7785
|
||||||
explain select product, country_id , year, sum(profit) from t1 group by product, country_id, year with rollup;
|
explain extended select product, country_id , year, sum(profit) from t1 group by product, country_id, year with rollup;
|
||||||
id select_type table type possible_keys key key_len ref rows Extra
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
1 SIMPLE t1 ALL NULL NULL NULL NULL 15 Using temporary; Using filesort
|
1 SIMPLE t1 ALL NULL NULL NULL NULL 15 Using temporary; Using filesort
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority test.t1.product AS `product`,test.t1.country_id AS `country_id`,test.t1.year AS `year`,sum(test.t1.profit) AS `sum(profit)` from test.t1 group by test.t1.product,test.t1.country_id,test.t1.year with rollup
|
||||||
select product, country_id , sum(profit) from t1 group by product desc, country_id with rollup;
|
select product, country_id , sum(profit) from t1 group by product desc, country_id with rollup;
|
||||||
product country_id sum(profit)
|
product country_id sum(profit)
|
||||||
TV 1 400
|
TV 1 400
|
||||||
|
@ -300,6 +300,11 @@ select USER() from t1;
|
|||||||
USER()
|
USER()
|
||||||
select benchmark(1,1) from t1;
|
select benchmark(1,1) from t1;
|
||||||
benchmark(1,1)
|
benchmark(1,1)
|
||||||
|
explain extended select benchmark(1,1) from t1;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t1 system NULL NULL NULL NULL 0 const row not found
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority no_cache benchmark(1,1) AS `benchmark(1,1)` from test.t1
|
||||||
show status like "Qcache_queries_in_cache";
|
show status like "Qcache_queries_in_cache";
|
||||||
Variable_name Value
|
Variable_name Value
|
||||||
Qcache_queries_in_cache 0
|
Qcache_queries_in_cache 0
|
||||||
|
@ -40,6 +40,11 @@ ERROR 21000: Operand should contain 2 column(s)
|
|||||||
select row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,row(3,NULL)));
|
select row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,row(3,NULL)));
|
||||||
row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,row(3,NULL)))
|
row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,row(3,NULL)))
|
||||||
NULL
|
NULL
|
||||||
|
explain extended select row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,row(3,NULL)));
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority ((1,2,(3,4)) in ((3,2,(3,4)),(1,2,(3,NULL)))) AS `row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,row(3,NULL)))`
|
||||||
SELECT (1,2,3)=(0,NULL,3);
|
SELECT (1,2,3)=(0,NULL,3);
|
||||||
(1,2,3)=(0,NULL,3)
|
(1,2,3)=(0,NULL,3)
|
||||||
0
|
0
|
||||||
|
@ -40,10 +40,20 @@ create table t1(n int);
|
|||||||
select get_lock("hold_slave",10);
|
select get_lock("hold_slave",10);
|
||||||
get_lock("hold_slave",10)
|
get_lock("hold_slave",10)
|
||||||
1
|
1
|
||||||
|
explain extended select get_lock("hold_slave",10);
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority no_cache get_lock(_latin1'hold_slave',10) AS `get_lock("hold_slave",10)`
|
||||||
start slave;
|
start slave;
|
||||||
select release_lock("hold_slave");
|
select release_lock("hold_slave");
|
||||||
release_lock("hold_slave")
|
release_lock("hold_slave")
|
||||||
1
|
1
|
||||||
|
explain extended select release_lock("hold_slave");
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority no_cache release_lock(_latin1'hold_slave') AS `release_lock("hold_slave")`
|
||||||
unlock tables;
|
unlock tables;
|
||||||
create table t2(id int);
|
create table t2(id int);
|
||||||
insert into t2 values(connection_id());
|
insert into t2 values(connection_id());
|
||||||
|
@ -18,9 +18,14 @@ get_lock("lock",3)
|
|||||||
select * from t1;
|
select * from t1;
|
||||||
n
|
n
|
||||||
1
|
1
|
||||||
select is_free_lock("lock");
|
select is_free_lock("lock"), is_used_lock("lock");
|
||||||
is_free_lock("lock")
|
is_free_lock("lock") is_used_lock("lock")
|
||||||
0
|
0 6
|
||||||
|
explain extended select is_free_lock("lock"), is_used_lock("lock");
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority no_cache is_free_lock(_latin1'lock') AS `is_free_lock("lock")`,is_used_lock(_latin1'lock') AS `is_used_lock("lock")`
|
||||||
select is_free_lock("lock2");
|
select is_free_lock("lock2");
|
||||||
is_free_lock("lock2")
|
is_free_lock("lock2")
|
||||||
1
|
1
|
||||||
|
@ -7,6 +7,11 @@ start slave;
|
|||||||
select master_pos_wait('master-bin.999999',0,2);
|
select master_pos_wait('master-bin.999999',0,2);
|
||||||
master_pos_wait('master-bin.999999',0,2)
|
master_pos_wait('master-bin.999999',0,2)
|
||||||
-1
|
-1
|
||||||
|
explain extended select master_pos_wait('master-bin.999999',0,2);
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority no_cache master_pos_wait(_latin1'master-bin.999999',0,2) AS `master_pos_wait('master-bin.999999',0,2)`
|
||||||
select master_pos_wait('master-bin.999999',0);
|
select master_pos_wait('master-bin.999999',0);
|
||||||
stop slave sql_thread;
|
stop slave sql_thread;
|
||||||
master_pos_wait('master-bin.999999',0)
|
master_pos_wait('master-bin.999999',0)
|
||||||
|
@ -1466,6 +1466,11 @@ companynr count(*)
|
|||||||
select count(*),min(fld4),max(fld4),sum(fld1),avg(fld1),std(fld1),variance(fld1) from t2 where companynr = 34 and fld4<>"";
|
select count(*),min(fld4),max(fld4),sum(fld1),avg(fld1),std(fld1),variance(fld1) from t2 where companynr = 34 and fld4<>"";
|
||||||
count(*) min(fld4) max(fld4) sum(fld1) avg(fld1) std(fld1) variance(fld1)
|
count(*) min(fld4) max(fld4) sum(fld1) avg(fld1) std(fld1) variance(fld1)
|
||||||
70 absentee vest 17788966 254128.0857 3272.5940 10709871.3069
|
70 absentee vest 17788966 254128.0857 3272.5940 10709871.3069
|
||||||
|
explain extended select count(*),min(fld4),max(fld4),sum(fld1),avg(fld1),std(fld1),variance(fld1) from t2 where companynr = 34 and fld4<>"";
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE t2 ALL NULL NULL NULL NULL 1199 Using where
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority count(0) AS `count(*)`,min(test.t2.fld4) AS `min(fld4)`,max(test.t2.fld4) AS `max(fld4)`,sum(test.t2.fld1) AS `sum(fld1)`,avg(test.t2.fld1) AS `avg(fld1)`,std(test.t2.fld1) AS `std(fld1)`,variance(test.t2.fld1) AS `variance(fld1)` from test.t2 where ((test.t2.companynr = 34) and (test.t2.fld4 <> _latin1''))
|
||||||
select companynr,count(*),min(fld4),max(fld4),sum(fld1),avg(fld1),std(fld1),variance(fld1) from t2 group by companynr limit 3;
|
select companynr,count(*),min(fld4),max(fld4),sum(fld1),avg(fld1),std(fld1),variance(fld1) from t2 group by companynr limit 3;
|
||||||
companynr count(*) min(fld4) max(fld4) sum(fld1) avg(fld1) std(fld1) variance(fld1)
|
companynr count(*) min(fld4) max(fld4) sum(fld1) avg(fld1) std(fld1) variance(fld1)
|
||||||
00 82 Anthony windmills 10355753 126289.6707 115550.9757 13352027981.7087
|
00 82 Anthony windmills 10355753 126289.6707 115550.9757 13352027981.7087
|
||||||
|
@ -199,7 +199,7 @@ id select_type table type possible_keys key key_len ref rows Extra
|
|||||||
3 DERIVED t2 ALL NULL NULL NULL NULL 2 Using where
|
3 DERIVED t2 ALL NULL NULL NULL NULL 2 Using where
|
||||||
2 SUBQUERY t3 ALL NULL NULL NULL NULL 3 Using where; Using filesort
|
2 SUBQUERY t3 ALL NULL NULL NULL NULL 3 Using where; Using filesort
|
||||||
Warnings:
|
Warnings:
|
||||||
Note 1003 select high_priority (select test.t3.a AS `a` from test.t3 where (test.t3.a < 8) order by test.t3.a desc limit 1) AS `(select t3.a from t3 where a<8 order by 1 desc limit 1)`,t2.a AS `a` from (select test.t2.a AS `a`,test.t2.b AS `b` from test.t2 where (test.t2.a > 1)) tt
|
Note 1003 select high_priority (select test.t3.a AS `a` from test.t3 where (test.t3.a < 8) order by test.t3.a desc limit 1) AS `(select t3.a from t3 where a<8 order by 1 desc limit 1)`,tt.a AS `a` from (select test.t2.a AS `a`,test.t2.b AS `b` from test.t2 where (test.t2.a > 1)) tt
|
||||||
select * from t1 where t1.a=(select t2.a from t2 where t2.b=(select max(a) from t3) order by 1 desc limit 1);
|
select * from t1 where t1.a=(select t2.a from t2 where t2.b=(select max(a) from t3) order by 1 desc limit 1);
|
||||||
a
|
a
|
||||||
2
|
2
|
||||||
@ -1013,7 +1013,7 @@ id select_type table type possible_keys key key_len ref rows Extra
|
|||||||
1 PRIMARY t1 system NULL NULL NULL NULL 0 const row not found
|
1 PRIMARY t1 system NULL NULL NULL NULL 0 const row not found
|
||||||
2 UNCACHEABLE SUBQUERY t1 system NULL NULL NULL NULL 0 const row not found
|
2 UNCACHEABLE SUBQUERY t1 system NULL NULL NULL NULL 0 const row not found
|
||||||
Warnings:
|
Warnings:
|
||||||
Note 1003 select high_priority no_cache (select no_cache benchmark(1) AS `BENCHMARK(1,1)` from test.t1) AS `(SELECT BENCHMARK(1,1) FROM t1)` from test.t1
|
Note 1003 select high_priority no_cache (select no_cache benchmark(1,1) AS `BENCHMARK(1,1)` from test.t1) AS `(SELECT BENCHMARK(1,1) FROM t1)` from test.t1
|
||||||
drop table t1;
|
drop table t1;
|
||||||
CREATE TABLE `t1` (
|
CREATE TABLE `t1` (
|
||||||
`mot` varchar(30) character set latin1 NOT NULL default '',
|
`mot` varchar(30) character set latin1 NOT NULL default '',
|
||||||
@ -1486,16 +1486,20 @@ explain extended select s1, s1 NOT IN (SELECT s1 FROM t2) from t1;
|
|||||||
id select_type table type possible_keys key key_len ref rows Extra
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
1 PRIMARY t1 index NULL s1 6 NULL 3 Using index
|
1 PRIMARY t1 index NULL s1 6 NULL 3 Using index
|
||||||
2 DEPENDENT SUBQUERY t2 index_subquery s1 s1 6 func 2 Using index
|
2 DEPENDENT SUBQUERY t2 index_subquery s1 s1 6 func 2 Using index
|
||||||
explain select s1, s1 = ANY (SELECT s1 FROM t2) from t1;
|
Warnings:
|
||||||
id select_type table type possible_keys key key_len ref rows Extra
|
Note 1003 select high_priority test.t1.s1 AS `s1`,not(<in_optimizer>(test.t1.s1,<exists>(<index_lookup>(<cache>(test.t1.s1) in t2 on s1 chicking NULL)))) AS `s1 NOT IN (SELECT s1 FROM t2)` from test.t1
|
||||||
1 PRIMARY t1 index NULL s1 6 NULL 3 Using index
|
explain extended select s1, s1 = ANY (SELECT s1 FROM t2) from t1;
|
||||||
2 DEPENDENT SUBQUERY t2 index_subquery s1 s1 6 func 2 Using index
|
|
||||||
explain select s1, s1 <> ALL (SELECT s1 FROM t2) from t1;
|
|
||||||
id select_type table type possible_keys key key_len ref rows Extra
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
1 PRIMARY t1 index NULL s1 6 NULL 3 Using index
|
1 PRIMARY t1 index NULL s1 6 NULL 3 Using index
|
||||||
2 DEPENDENT SUBQUERY t2 index_subquery s1 s1 6 func 2 Using index
|
2 DEPENDENT SUBQUERY t2 index_subquery s1 s1 6 func 2 Using index
|
||||||
Warnings:
|
Warnings:
|
||||||
Note 1003 select high_priority test.t1.s1 AS `s1`,not(<in_optimizer>(test.t1.s1,<exists>(<index_lookup>(<cache>(test.t1.s1) in t2 on s1 chicking NULL)))) AS `s1 NOT IN (SELECT s1 FROM t2)` from test.t1
|
Note 1003 select high_priority test.t1.s1 AS `s1`,<in_optimizer>(test.t1.s1,<exists>(<index_lookup>(<cache>(test.t1.s1) in t2 on s1 chicking NULL))) AS `s1 = ANY (SELECT s1 FROM t2)` from test.t1
|
||||||
|
explain extended select s1, s1 <> ALL (SELECT s1 FROM t2) from t1;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 PRIMARY t1 index NULL s1 6 NULL 3 Using index
|
||||||
|
2 DEPENDENT SUBQUERY t2 index_subquery s1 s1 6 func 2 Using index
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority test.t1.s1 AS `s1`,not(<in_optimizer>(test.t1.s1,<exists>(<index_lookup>(<cache>(test.t1.s1) in t2 on s1 chicking NULL)))) AS `s1 <> ALL (SELECT s1 FROM t2)` from test.t1
|
||||||
explain extended select s1, s1 NOT IN (SELECT s1 FROM t2 WHERE s1 < 'a2') from t1;
|
explain extended select s1, s1 NOT IN (SELECT s1 FROM t2 WHERE s1 < 'a2') from t1;
|
||||||
id select_type table type possible_keys key key_len ref rows Extra
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
1 PRIMARY t1 index NULL s1 6 NULL 3 Using index
|
1 PRIMARY t1 index NULL s1 6 NULL 3 Using index
|
||||||
|
@ -492,6 +492,14 @@ collation(load_file('../../std_data/words.dat')),
|
|||||||
coercibility(load_file('../../std_data/words.dat'));
|
coercibility(load_file('../../std_data/words.dat'));
|
||||||
charset(load_file('../../std_data/words.dat')) collation(load_file('../../std_data/words.dat')) coercibility(load_file('../../std_data/words.dat'))
|
charset(load_file('../../std_data/words.dat')) collation(load_file('../../std_data/words.dat')) coercibility(load_file('../../std_data/words.dat'))
|
||||||
binary binary 3
|
binary binary 3
|
||||||
|
explain extended select
|
||||||
|
charset(load_file('../../std_data/words.dat')),
|
||||||
|
collation(load_file('../../std_data/words.dat')),
|
||||||
|
coercibility(load_file('../../std_data/words.dat'));
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority no_cache charset(load_file(_latin1'../../std_data/words.dat')) AS `charset(load_file('../../std_data/words.dat'))`,collation(load_file(_latin1'../../std_data/words.dat')) AS `collation(load_file('../../std_data/words.dat'))`,coercibility(load_file(_latin1'../../std_data/words.dat')) AS `coercibility(load_file('../../std_data/words.dat'))`
|
||||||
update t1 set imagem=load_file('../../std_data/words.dat') where id=1;
|
update t1 set imagem=load_file('../../std_data/words.dat') where id=1;
|
||||||
select if(imagem is null, "ERROR", "OK"),length(imagem) from t1 where id = 1;
|
select if(imagem is null, "ERROR", "OK"),length(imagem) from t1 where id = 1;
|
||||||
if(imagem is null, "ERROR", "OK") length(imagem)
|
if(imagem is null, "ERROR", "OK") length(imagem)
|
||||||
|
@ -11,9 +11,11 @@ x'31' X'ffff'+0
|
|||||||
create table t1 (ID int(8) unsigned zerofill not null auto_increment,UNIQ bigint(21) unsigned zerofill not null,primary key (ID),unique (UNIQ) );
|
create table t1 (ID int(8) unsigned zerofill not null auto_increment,UNIQ bigint(21) unsigned zerofill not null,primary key (ID),unique (UNIQ) );
|
||||||
insert into t1 set UNIQ=0x38afba1d73e6a18a;
|
insert into t1 set UNIQ=0x38afba1d73e6a18a;
|
||||||
insert into t1 set UNIQ=123;
|
insert into t1 set UNIQ=123;
|
||||||
explain select * from t1 where UNIQ=0x38afba1d73e6a18a;
|
explain extended select * from t1 where UNIQ=0x38afba1d73e6a18a;
|
||||||
id select_type table type possible_keys key key_len ref rows Extra
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
1 SIMPLE t1 const UNIQ UNIQ 8 const 1
|
1 SIMPLE t1 const UNIQ UNIQ 8 const 1
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority test.t1.ID AS `ID`,test.t1.UNIQ AS `UNIQ` from test.t1 where (test.t1.UNIQ = 4084688022709641610)
|
||||||
drop table t1;
|
drop table t1;
|
||||||
select x'hello';
|
select x'hello';
|
||||||
ERROR 42000: You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'x'hello'' at line 1
|
ERROR 42000: You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'x'hello'' at line 1
|
||||||
|
@ -22,6 +22,11 @@ NULL NULL NULL NULL
|
|||||||
select @t1:=(@t2:=1)+@t3:=4,@t1,@t2,@t3;
|
select @t1:=(@t2:=1)+@t3:=4,@t1,@t2,@t3;
|
||||||
@t1:=(@t2:=1)+@t3:=4 @t1 @t2 @t3
|
@t1:=(@t2:=1)+@t3:=4 @t1 @t2 @t3
|
||||||
5 5 1 4
|
5 5 1 4
|
||||||
|
explain extended select @t1:=(@t2:=1)+@t3:=4,@t1,@t2,@t3;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority no_cache (@t1:=((@t2:=1) + (@t3:=4))) AS `@t1:=(@t2:=1)+@t3:=4`,(@t1) AS `@t1`,(@t2) AS `@t2`,(@t3) AS `@t3`
|
||||||
select @t5;
|
select @t5;
|
||||||
@t5
|
@t5
|
||||||
1.23456
|
1.23456
|
||||||
@ -76,9 +81,19 @@ select @@VERSION=version();
|
|||||||
select last_insert_id(345);
|
select last_insert_id(345);
|
||||||
last_insert_id(345)
|
last_insert_id(345)
|
||||||
345
|
345
|
||||||
|
explain extended select last_insert_id(345);
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority no_cache last_insert_id(345) AS `last_insert_id(345)`
|
||||||
select @@IDENTITY,last_insert_id(), @@identity;
|
select @@IDENTITY,last_insert_id(), @@identity;
|
||||||
@@IDENTITY last_insert_id() @@identity
|
@@IDENTITY last_insert_id() @@identity
|
||||||
345 345 345
|
345 345 345
|
||||||
|
explain extended select @@IDENTITY,last_insert_id(), @@identity;
|
||||||
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
||||||
|
Warnings:
|
||||||
|
Note 1003 select high_priority no_cache 345 AS `@@IDENTITY`,345 AS `last_insert_id()`,345 AS `@@identity`
|
||||||
set big_tables=OFF, big_tables=ON, big_tables=0, big_tables=1, big_tables="OFF", big_tables="ON";
|
set big_tables=OFF, big_tables=ON, big_tables=0, big_tables=1, big_tables="OFF", big_tables="ON";
|
||||||
set global concurrent_insert=ON;
|
set global concurrent_insert=ON;
|
||||||
show variables like 'concurrent_insert';
|
show variables like 'concurrent_insert';
|
||||||
|
@ -80,6 +80,7 @@ create table t1 (i tinyint unsigned not null auto_increment primary key);
|
|||||||
insert into t1 set i = 254;
|
insert into t1 set i = 254;
|
||||||
insert into t1 set i = null;
|
insert into t1 set i = null;
|
||||||
select last_insert_id();
|
select last_insert_id();
|
||||||
|
explain extended select last_insert_id();
|
||||||
--error 1062
|
--error 1062
|
||||||
insert into t1 set i = 254;
|
insert into t1 set i = 254;
|
||||||
select last_insert_id();
|
select last_insert_id();
|
||||||
|
@ -16,4 +16,5 @@ while ($1)
|
|||||||
}
|
}
|
||||||
enable_query_log;
|
enable_query_log;
|
||||||
select count(distinct n) from t1;
|
select count(distinct n) from t1;
|
||||||
|
explain extended select count(distinct n) from t1;
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
@ -14,6 +14,7 @@ select CASE "b" when "a" then 1 when binary "B" then 2 WHEN "b" then "ok" END;
|
|||||||
select CASE concat("a","b") when concat("ab","") then "a" when "b" then "b" end;
|
select CASE concat("a","b") when concat("ab","") then "a" when "b" then "b" end;
|
||||||
select CASE when 1=0 then "true" else "false" END;
|
select CASE when 1=0 then "true" else "false" END;
|
||||||
select CASE 1 when 1 then "one" WHEN 2 then "two" ELSE "more" END;
|
select CASE 1 when 1 then "one" WHEN 2 then "two" ELSE "more" END;
|
||||||
|
explain extended select CASE 1 when 1 then "one" WHEN 2 then "two" ELSE "more" END;
|
||||||
select CASE 2.0 when 1 then "one" WHEN 2.0 then "two" ELSE "more" END;
|
select CASE 2.0 when 1 then "one" WHEN 2.0 then "two" ELSE "more" END;
|
||||||
select (CASE "two" when "one" then "1" WHEN "two" then "2" END) | 0;
|
select (CASE "two" when "one" then "1" WHEN "two" then "2" END) | 0;
|
||||||
select (CASE "two" when "one" then 1.00 WHEN "two" then 2.00 END) +0.0;
|
select (CASE "two" when "one" then 1.00 WHEN "two" then 2.00 END) +0.0;
|
||||||
@ -30,6 +31,7 @@ select case when 1<0 then "TRUE" else "FALSE" END;
|
|||||||
create table t1 (a int);
|
create table t1 (a int);
|
||||||
insert into t1 values(1),(2),(3),(4);
|
insert into t1 values(1),(2),(3),(4);
|
||||||
select case a when 1 then 2 when 2 then 3 else 0 end as fcase, count(*) from t1 group by fcase;
|
select case a when 1 then 2 when 2 then 3 else 0 end as fcase, count(*) from t1 group by fcase;
|
||||||
|
explain extended select case a when 1 then 2 when 2 then 3 else 0 end as fcase, count(*) from t1 group by fcase;
|
||||||
select case a when 1 then "one" when 2 then "two" else "nothing" end as fcase, count(*) from t1 group by fcase;
|
select case a when 1 then "one" when 2 then "two" else "nothing" end as fcase, count(*) from t1 group by fcase;
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
|
||||||
@ -98,5 +100,9 @@ CREATE TABLE t1 SELECT
|
|||||||
COALESCE(1), COALESCE(1.0),COALESCE('a'),
|
COALESCE(1), COALESCE(1.0),COALESCE('a'),
|
||||||
COALESCE(1,1.0), COALESCE(1,'1'),COALESCE(1.1,'1'),
|
COALESCE(1,1.0), COALESCE(1,'1'),COALESCE(1.1,'1'),
|
||||||
COALESCE('a' COLLATE latin1_bin,'b');
|
COALESCE('a' COLLATE latin1_bin,'b');
|
||||||
|
explain extended SELECT
|
||||||
|
COALESCE(1), COALESCE(1.0),COALESCE('a'),
|
||||||
|
COALESCE(1,1.0), COALESCE(1,'1'),COALESCE(1.1,'1'),
|
||||||
|
COALESCE('a' COLLATE latin1_bin,'b');
|
||||||
SHOW CREATE TABLE t1;
|
SHOW CREATE TABLE t1;
|
||||||
DROP TABLE t1;
|
DROP TABLE t1;
|
||||||
|
@ -8,6 +8,7 @@ select CONVERT('-1',UNSIGNED);
|
|||||||
select cast(-5 as unsigned) | 1, cast(-5 as unsigned) & -1;
|
select cast(-5 as unsigned) | 1, cast(-5 as unsigned) & -1;
|
||||||
select cast(-5 as unsigned) -1, cast(-5 as unsigned) + 1;
|
select cast(-5 as unsigned) -1, cast(-5 as unsigned) + 1;
|
||||||
select ~5, cast(~5 as signed);
|
select ~5, cast(~5 as signed);
|
||||||
|
explain extended select ~5, cast(~5 as signed);
|
||||||
select cast(5 as unsigned) -6.0;
|
select cast(5 as unsigned) -6.0;
|
||||||
select cast("A" as binary) = "a", cast(BINARY "a" as CHAR) = "A";
|
select cast("A" as binary) = "a", cast(BINARY "a" as CHAR) = "A";
|
||||||
select cast("2001-1-1" as DATE), cast("2001-1-1" as DATETIME);
|
select cast("2001-1-1" as DATE), cast("2001-1-1" as DATETIME);
|
||||||
|
@ -139,6 +139,7 @@ SHOW FIELDS FROM t1;
|
|||||||
SET CHARACTER SET 'latin1';
|
SET CHARACTER SET 'latin1';
|
||||||
SHOW VARIABLES LIKE 'character_set_client';
|
SHOW VARIABLES LIKE 'character_set_client';
|
||||||
SELECT charset('a'),collation('a'),coercibility('a'),'a'='A';
|
SELECT charset('a'),collation('a'),coercibility('a'),'a'='A';
|
||||||
|
explain extended SELECT charset('a'),collation('a'),coercibility('a'),'a'='A';
|
||||||
|
|
||||||
SET CHARACTER SET koi8r;
|
SET CHARACTER SET koi8r;
|
||||||
SHOW VARIABLES LIKE 'collation_client';
|
SHOW VARIABLES LIKE 'collation_client';
|
||||||
|
@ -147,6 +147,12 @@ UPDATE t1 SET utf8_f=CONVERT(koi8_ru_f USING utf8);
|
|||||||
SET CHARACTER SET koi8r;
|
SET CHARACTER SET koi8r;
|
||||||
SELECT * FROM t1;
|
SELECT * FROM t1;
|
||||||
|
|
||||||
|
#
|
||||||
|
# codecovarage for Item_func_conv_charset3
|
||||||
|
#
|
||||||
|
select CONVERT(koi8_ru_f, 'cp1251_general_ci', 'utf8_general_ci'), comment from t1;
|
||||||
|
explain extended select CONVERT(koi8_ru_f, 'cp1251_general_ci', 'utf8_general_ci'), comment from t1;
|
||||||
|
|
||||||
ALTER TABLE t1 ADD bin_f CHAR(32) BYTE NOT NULL;
|
ALTER TABLE t1 ADD bin_f CHAR(32) BYTE NOT NULL;
|
||||||
UPDATE t1 SET bin_f=koi8_ru_f;
|
UPDATE t1 SET bin_f=koi8_ru_f;
|
||||||
SELECT COUNT(DISTINCT bin_f),COUNT(DISTINCT koi8_ru_f),COUNT(DISTINCT utf8_f) FROM t1;
|
SELECT COUNT(DISTINCT bin_f),COUNT(DISTINCT koi8_ru_f),COUNT(DISTINCT utf8_f) FROM t1;
|
||||||
|
@ -23,6 +23,8 @@ select locate(_utf8 0xD0B1, _utf8 0xD0B0D091D0B2);
|
|||||||
select locate(_utf8 0xD091, _utf8 0xD0B0D0B1D0B2 collate utf8_bin);
|
select locate(_utf8 0xD091, _utf8 0xD0B0D0B1D0B2 collate utf8_bin);
|
||||||
select locate(_utf8 0xD0B1, _utf8 0xD0B0D091D0B2 collate utf8_bin);
|
select locate(_utf8 0xD0B1, _utf8 0xD0B0D091D0B2 collate utf8_bin);
|
||||||
|
|
||||||
|
select length(_utf8 0xD0B1), bit_length(_utf8 0xD0B1), char_length(_utf8 0xD0B1);
|
||||||
|
|
||||||
select 'a' like 'a';
|
select 'a' like 'a';
|
||||||
select 'A' like 'a';
|
select 'A' like 'a';
|
||||||
select 'A' like 'a' collate utf8_bin;
|
select 'A' like 'a' collate utf8_bin;
|
||||||
|
@ -80,3 +80,4 @@ select get_format(DATE, 'USA') as a;
|
|||||||
select get_format(TIME, 'internal') as a;
|
select get_format(TIME, 'internal') as a;
|
||||||
select get_format(DATETIME, 'eur') as a;
|
select get_format(DATETIME, 'eur') as a;
|
||||||
|
|
||||||
|
explain extended select makedate(1997,1), addtime("31.12.97 11.59.59.999999 PM", "1 1.1.1.000002"),subtime("31.12.97 11.59.59.999999 PM", "1 1.1.1.000002"),timediff("01.01.97 11:59:59.000001 PM","31.12.95 11:59:59.000002 PM"),cast(str_to_date("15-01-2001 12:59:59", "%d-%m-%Y %H:%i:%S") as TIME), maketime(23,11,12),microsecond("1997-12-31 23:59:59.000001");
|
||||||
|
@ -16,6 +16,7 @@ INSERT INTO t1 VALUES('MySQL has now support', 'for full-text search'),
|
|||||||
# nl search
|
# nl search
|
||||||
|
|
||||||
select * from t1 where MATCH(a,b) AGAINST ("collections");
|
select * from t1 where MATCH(a,b) AGAINST ("collections");
|
||||||
|
explain extended select * from t1 where MATCH(a,b) AGAINST ("collections");
|
||||||
select * from t1 where MATCH(a,b) AGAINST ("indexes");
|
select * from t1 where MATCH(a,b) AGAINST ("indexes");
|
||||||
select * from t1 where MATCH(a,b) AGAINST ("indexes collections");
|
select * from t1 where MATCH(a,b) AGAINST ("indexes collections");
|
||||||
select * from t1 where MATCH(a,b) AGAINST ("only");
|
select * from t1 where MATCH(a,b) AGAINST ("only");
|
||||||
@ -40,6 +41,7 @@ explain select * from t1 where MATCH(a,b) AGAINST ("collections")>0 and a like '
|
|||||||
# boolean search
|
# boolean search
|
||||||
|
|
||||||
select * from t1 where MATCH(a,b) AGAINST("support -collections" IN BOOLEAN MODE);
|
select * from t1 where MATCH(a,b) AGAINST("support -collections" IN BOOLEAN MODE);
|
||||||
|
explain extended select * from t1 where MATCH(a,b) AGAINST("support -collections" IN BOOLEAN MODE);
|
||||||
select * from t1 where MATCH(a,b) AGAINST("support collections" IN BOOLEAN MODE);
|
select * from t1 where MATCH(a,b) AGAINST("support collections" IN BOOLEAN MODE);
|
||||||
select * from t1 where MATCH(a,b) AGAINST("support +collections" IN BOOLEAN MODE);
|
select * from t1 where MATCH(a,b) AGAINST("support +collections" IN BOOLEAN MODE);
|
||||||
select * from t1 where MATCH(a,b) AGAINST("sear*" IN BOOLEAN MODE);
|
select * from t1 where MATCH(a,b) AGAINST("sear*" IN BOOLEAN MODE);
|
||||||
|
@ -7,7 +7,9 @@ select @test_compress_string:='string for test compress function aaaaaaaaaaaaaaa
|
|||||||
select length(@test_compress_string);
|
select length(@test_compress_string);
|
||||||
|
|
||||||
select uncompress(compress(@test_compress_string));
|
select uncompress(compress(@test_compress_string));
|
||||||
|
explain extended select uncompress(compress(@test_compress_string));
|
||||||
select uncompressed_length(compress(@test_compress_string))=length(@test_compress_string);
|
select uncompressed_length(compress(@test_compress_string))=length(@test_compress_string);
|
||||||
|
explain extended select uncompressed_length(compress(@test_compress_string))=length(@test_compress_string);
|
||||||
select uncompressed_length(compress(@test_compress_string));
|
select uncompressed_length(compress(@test_compress_string));
|
||||||
select length(compress(@test_compress_string))<length(@test_compress_string);
|
select length(compress(@test_compress_string))<length(@test_compress_string);
|
||||||
|
|
||||||
|
@ -18,6 +18,7 @@ insert into t1 values (3,9,"D","c");
|
|||||||
|
|
||||||
# Test of MySQL simple request
|
# Test of MySQL simple request
|
||||||
select grp,group_concat(c) from t1 group by grp;
|
select grp,group_concat(c) from t1 group by grp;
|
||||||
|
explain extended select grp,group_concat(c) from t1 group by grp;
|
||||||
select grp,group_concat(a,c) from t1 group by grp;
|
select grp,group_concat(a,c) from t1 group by grp;
|
||||||
select grp,group_concat("(",a,":",c,")") from t1 group by grp;
|
select grp,group_concat("(",a,":",c,")") from t1 group by grp;
|
||||||
|
|
||||||
@ -33,9 +34,11 @@ select grp,group_concat(c order by 1) from t1 group by grp;
|
|||||||
select grp,group_concat(c order by "c") from t1 group by grp;
|
select grp,group_concat(c order by "c") from t1 group by grp;
|
||||||
select grp,group_concat(distinct c order by c) from t1 group by grp;
|
select grp,group_concat(distinct c order by c) from t1 group by grp;
|
||||||
select grp,group_concat(distinct c order by c desc) from t1 group by grp;
|
select grp,group_concat(distinct c order by c desc) from t1 group by grp;
|
||||||
|
explain extended select grp,group_concat(distinct c order by c desc) from t1 group by grp;
|
||||||
select grp,group_concat(c order by c separator ",") from t1 group by grp;
|
select grp,group_concat(c order by c separator ",") from t1 group by grp;
|
||||||
select grp,group_concat(c order by c desc separator ",") from t1 group by grp;
|
select grp,group_concat(c order by c desc separator ",") from t1 group by grp;
|
||||||
select grp,group_concat(distinct c order by c separator ",") from t1 group by grp;
|
select grp,group_concat(distinct c order by c separator ",") from t1 group by grp;
|
||||||
|
explain extended select grp,group_concat(distinct c order by c separator ",") from t1 group by grp;
|
||||||
select grp,group_concat(distinct c order by c desc separator ",") from t1 group by grp;
|
select grp,group_concat(distinct c order by c desc separator ",") from t1 group by grp;
|
||||||
|
|
||||||
# Test of SQL_LIST objects
|
# Test of SQL_LIST objects
|
||||||
|
@ -346,7 +346,8 @@ select a,count(b), sum(b), avg(b), std(b), min(b), max(b), bit_and(b), bit_or(b)
|
|||||||
select SQL_BIG_RESULT a,count(b), sum(b), avg(b), std(b), min(b), max(b), bit_and(b), bit_or(b) from t1 group by a;
|
select SQL_BIG_RESULT a,count(b), sum(b), avg(b), std(b), min(b), max(b), bit_and(b), bit_or(b) from t1 group by a;
|
||||||
insert into t1 values (3,1);
|
insert into t1 values (3,1);
|
||||||
select a,count(b), sum(b), avg(b), std(b), min(b), max(b), bit_and(b), bit_or(b) from t1 group by a;
|
select a,count(b), sum(b), avg(b), std(b), min(b), max(b), bit_and(b), bit_or(b) from t1 group by a;
|
||||||
select SQL_BIG_RESULT a,count(b), sum(b), avg(b), std(b), min(b), max(b), bit_and(b), bit_or(b) from t1 group by a;
|
select SQL_BIG_RESULT a,count(b), sum(b), avg(b), std(b), min(b), max(b), bit_and(b), bit_or(b), bit_xor(b) from t1 group by a;
|
||||||
|
explain extended select SQL_BIG_RESULT a,count(b), sum(b), avg(b), std(b), min(b), max(b), bit_and(b), bit_or(b), bit_xor(b) from t1 group by a;
|
||||||
drop table t1;
|
drop table t1;
|
||||||
--disable_warnings
|
--disable_warnings
|
||||||
create table t1 (USR_ID integer not null, MAX_REQ integer not null, constraint PK_SEA_USER primary key (USR_ID)) type=InnoDB;
|
create table t1 (USR_ID integer not null, MAX_REQ integer not null, constraint PK_SEA_USER primary key (USR_ID)) type=InnoDB;
|
||||||
|
@ -20,6 +20,13 @@ select if(1,st,st) s from t1 order by s;
|
|||||||
select if(u=1,st,st) s from t1 order by s;
|
select if(u=1,st,st) s from t1 order by s;
|
||||||
select if(u=1,binary st,st) s from t1 order by s;
|
select if(u=1,binary st,st) s from t1 order by s;
|
||||||
select if(u=1,st,binary st) s from t1 where st like "%a%" order by s;
|
select if(u=1,st,binary st) s from t1 where st like "%a%" order by s;
|
||||||
|
explain extended select if(u=1,st,binary st) s from t1 where st like "%a%" order by s;
|
||||||
|
|
||||||
|
#
|
||||||
|
# NULLIF test
|
||||||
|
#
|
||||||
|
select nullif(u=0, 'test') from t1;
|
||||||
|
explain extended select nullif(u=0, 'test') from t1;
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
|
||||||
#
|
#
|
||||||
|
@ -72,6 +72,7 @@ select * from t1 where a in ('a');
|
|||||||
select * from t1 where 'a' collate latin1_general_ci in (a,b,c);
|
select * from t1 where 'a' collate latin1_general_ci in (a,b,c);
|
||||||
select * from t1 where 'a' collate latin1_bin in (a,b,c);
|
select * from t1 where 'a' collate latin1_bin in (a,b,c);
|
||||||
select * from t1 where 'a' in (a,b,c collate latin1_bin);
|
select * from t1 where 'a' in (a,b,c collate latin1_bin);
|
||||||
|
explain extended select * from t1 where 'a' in (a,b,c collate latin1_bin);
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
|
||||||
select '1.0' in (1,2);
|
select '1.0' in (1,2);
|
||||||
|
@ -3,17 +3,30 @@
|
|||||||
#
|
#
|
||||||
|
|
||||||
select floor(5.5),floor(-5.5);
|
select floor(5.5),floor(-5.5);
|
||||||
|
explain extended select floor(5.5),floor(-5.5);
|
||||||
select ceiling(5.5),ceiling(-5.5);
|
select ceiling(5.5),ceiling(-5.5);
|
||||||
|
explain extended select ceiling(5.5),ceiling(-5.5);
|
||||||
select truncate(52.64,1),truncate(52.64,2),truncate(52.64,-1),truncate(52.64,-2), truncate(-52.64,1),truncate(-52.64,-1);
|
select truncate(52.64,1),truncate(52.64,2),truncate(52.64,-1),truncate(52.64,-2), truncate(-52.64,1),truncate(-52.64,-1);
|
||||||
|
explain extended select truncate(52.64,1),truncate(52.64,2),truncate(52.64,-1),truncate(52.64,-2), truncate(-52.64,1),truncate(-52.64,-1);
|
||||||
select round(5.5),round(-5.5);
|
select round(5.5),round(-5.5);
|
||||||
|
explain extended select round(5.5),round(-5.5);
|
||||||
select round(5.64,1),round(5.64,2),round(5.64,-1),round(5.64,-2);
|
select round(5.64,1),round(5.64,2),round(5.64,-1),round(5.64,-2);
|
||||||
select abs(-10), sign(-5), sign(5), sign(0);
|
select abs(-10), sign(-5), sign(5), sign(0);
|
||||||
|
explain extended select abs(-10), sign(-5), sign(5), sign(0);
|
||||||
select log(exp(10)),exp(log(sqrt(10))*2),log(-1),log(NULL),log(1,1),log(3,9),log(-1,2),log(NULL,2);
|
select log(exp(10)),exp(log(sqrt(10))*2),log(-1),log(NULL),log(1,1),log(3,9),log(-1,2),log(NULL,2);
|
||||||
|
explain extended select log(exp(10)),exp(log(sqrt(10))*2),log(-1),log(NULL),log(1,1),log(3,9),log(-1,2),log(NULL,2);
|
||||||
select ln(exp(10)),exp(ln(sqrt(10))*2),ln(-1),ln(0),ln(NULL);
|
select ln(exp(10)),exp(ln(sqrt(10))*2),ln(-1),ln(0),ln(NULL);
|
||||||
|
explain extended select ln(exp(10)),exp(ln(sqrt(10))*2),ln(-1),ln(0),ln(NULL);
|
||||||
select log2(8),log2(15),log2(-2),log2(0),log2(NULL);
|
select log2(8),log2(15),log2(-2),log2(0),log2(NULL);
|
||||||
|
explain extended select log2(8),log2(15),log2(-2),log2(0),log2(NULL);
|
||||||
select log10(100),log10(18),log10(-4),log10(0),log10(NULL);
|
select log10(100),log10(18),log10(-4),log10(0),log10(NULL);
|
||||||
|
explain extended select log10(100),log10(18),log10(-4),log10(0),log10(NULL);
|
||||||
select pow(10,log10(10)),power(2,4);
|
select pow(10,log10(10)),power(2,4);
|
||||||
|
explain extended select pow(10,log10(10)),power(2,4);
|
||||||
set @@rand_seed1=10000000,@@rand_seed2=1000000;
|
set @@rand_seed1=10000000,@@rand_seed2=1000000;
|
||||||
select rand(999999),rand();
|
select rand(999999),rand();
|
||||||
|
explain extended select rand(999999),rand();
|
||||||
select pi(),sin(pi()/2),cos(pi()/2),abs(tan(pi())),cot(1),asin(1),acos(0),atan(1);
|
select pi(),sin(pi()/2),cos(pi()/2),abs(tan(pi())),cot(1),asin(1),acos(0),atan(1);
|
||||||
|
explain extended select pi(),sin(pi()/2),cos(pi()/2),abs(tan(pi())),cot(1),asin(1),acos(0),atan(1);
|
||||||
select degrees(pi()),radians(360);
|
select degrees(pi()),radians(360);
|
||||||
|
explain extended select degrees(pi()),radians(360);
|
||||||
|
@ -3,5 +3,7 @@
|
|||||||
# Simple operands and arithmetic grouping
|
# Simple operands and arithmetic grouping
|
||||||
|
|
||||||
select 1+1,1-1,1+1*2,8/5,8%5,mod(8,5),mod(8,5)|0,-(1+1)*-2;
|
select 1+1,1-1,1+1*2,8/5,8%5,mod(8,5),mod(8,5)|0,-(1+1)*-2;
|
||||||
|
explain extended select 1+1,1-1,1+1*2,8/5,8%5,mod(8,5),mod(8,5)|0,-(1+1)*-2;
|
||||||
select 1 | (1+1),5 & 3,bit_count(7) ;
|
select 1 | (1+1),5 & 3,bit_count(7) ;
|
||||||
|
explain extended select 1 | (1+1),5 & 3,bit_count(7) ;
|
||||||
select 1 << 32,1 << 63, 1 << 64, 4 >> 2, 4 >> 63, 1<< 63 >> 60;
|
select 1 << 32,1 << 63, 1 << 64, 4 >> 2, 4 >> 63, 1<< 63 >> 60;
|
||||||
|
@ -36,6 +36,7 @@ drop table t1;
|
|||||||
create table t1 (xxx char(128));
|
create table t1 (xxx char(128));
|
||||||
insert into t1 (xxx) values('this is a test of some long text to see what happens');
|
insert into t1 (xxx) values('this is a test of some long text to see what happens');
|
||||||
select * from t1 where xxx regexp('is a test of some long text to');
|
select * from t1 where xxx regexp('is a test of some long text to');
|
||||||
|
explain extended select * from t1 where xxx regexp('is a test of some long text to');
|
||||||
select * from t1 where xxx regexp('is a test of some long text to ');
|
select * from t1 where xxx regexp('is a test of some long text to ');
|
||||||
select * from t1 where xxx regexp('is a test of some long text to s');
|
select * from t1 where xxx regexp('is a test of some long text to s');
|
||||||
select * from t1 where xxx regexp('is a test of some long text to se');
|
select * from t1 where xxx regexp('is a test of some long text to se');
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
#
|
#
|
||||||
|
|
||||||
select interval(55,10,20,30,40,50,60,70,80,90,100),interval(3,1,1+1,1+1+1+1),field("IBM","NCA","ICL","SUN","IBM","DIGITAL"),field("A","B","C"),elt(2,"ONE","TWO","THREE"),interval(0,1,2,3,4),elt(1,1,2,3)|0,elt(1,1.1,1.2,1.3)+0;
|
select interval(55,10,20,30,40,50,60,70,80,90,100),interval(3,1,1+1,1+1+1+1),field("IBM","NCA","ICL","SUN","IBM","DIGITAL"),field("A","B","C"),elt(2,"ONE","TWO","THREE"),interval(0,1,2,3,4),elt(1,1,2,3)|0,elt(1,1.1,1.2,1.3)+0;
|
||||||
|
explain extended select INTERVAL(55,10,20,30,40,50,60,70,80,90,100),interval(3,1,1+1,1+1+1+1),field("IBM","NCA","ICL","SUN","IBM","DIGITAL"),field("A","B","C"),elt(2,"ONE","TWO","THREE"),interval(0,1,2,3,4),elt(1,1,2,3)|0,elt(1,1.1,1.2,1.3)+0;
|
||||||
select find_in_set("b","a,b,c"),find_in_set("c","a,b,c"),find_in_set("dd","a,bbb,dd"),find_in_set("bbb","a,bbb,dd");
|
select find_in_set("b","a,b,c"),find_in_set("c","a,b,c"),find_in_set("dd","a,bbb,dd"),find_in_set("bbb","a,bbb,dd");
|
||||||
select find_in_set("d","a,b,c"),find_in_set("dd","a,bbb,d"),find_in_set("bb","a,bbb,dd");
|
select find_in_set("d","a,b,c"),find_in_set("dd","a,bbb,d"),find_in_set("bb","a,bbb,dd");
|
||||||
select make_set(0,'a','b','c'),make_set(-1,'a','b','c'),make_set(1,'a','b','c'),make_set(2,'a','b','c'),make_set(1+2,concat('a','b'),'c');
|
select make_set(0,'a','b','c'),make_set(-1,'a','b','c'),make_set(1,'a','b','c'),make_set(2,'a','b','c'),make_set(1+2,concat('a','b'),'c');
|
||||||
|
@ -14,7 +14,9 @@ select 'hello',"'hello'",'""hello""','''h''e''l''l''o''',"hel""lo",'hel\'lo';
|
|||||||
select 'hello' 'monty';
|
select 'hello' 'monty';
|
||||||
select length('\n\t\r\b\0\_\%\\');
|
select length('\n\t\r\b\0\_\%\\');
|
||||||
select bit_length('\n\t\r\b\0\_\%\\');
|
select bit_length('\n\t\r\b\0\_\%\\');
|
||||||
select concat('monty',' was here ','again'),length('hello'),char(ascii('h'));
|
select char_length('\n\t\r\b\0\_\%\\');
|
||||||
|
select length(_latin1'\n\t\n\b\0\\_\\%\\');
|
||||||
|
select concat('monty',' was here ','again'),length('hello'),char(ascii('h')),ord('h');
|
||||||
select locate('he','hello'),locate('he','hello',2),locate('lo','hello',2) ;
|
select locate('he','hello'),locate('he','hello',2),locate('lo','hello',2) ;
|
||||||
select instr('hello','HE'), instr('hello',binary 'HE'), instr(binary 'hello','HE');
|
select instr('hello','HE'), instr('hello',binary 'HE'), instr(binary 'hello','HE');
|
||||||
select position(binary 'll' in 'hello'),position('a' in binary 'hello');
|
select position(binary 'll' in 'hello'),position('a' in binary 'hello');
|
||||||
@ -46,6 +48,7 @@ select null sounds like 'null';
|
|||||||
select 'null' sounds like null;
|
select 'null' sounds like null;
|
||||||
select null sounds like null;
|
select null sounds like null;
|
||||||
select md5('hello');
|
select md5('hello');
|
||||||
|
select crc32("123");
|
||||||
select sha('abc');
|
select sha('abc');
|
||||||
select sha1('abc');
|
select sha1('abc');
|
||||||
select aes_decrypt(aes_encrypt('abc','1'),'1');
|
select aes_decrypt(aes_encrypt('abc','1'),'1');
|
||||||
@ -336,3 +339,5 @@ INSERT INTO t1 VALUES ('Congress reconvenes in September to debate welfare and a
|
|||||||
INSERT INTO t1 VALUES ('House passes the CAREERS bill');
|
INSERT INTO t1 VALUES ('House passes the CAREERS bill');
|
||||||
SELECT CONCAT("</a>",RPAD("",(55 - LENGTH(title)),".")) from t1;
|
SELECT CONCAT("</a>",RPAD("",(55 - LENGTH(title)),".")) from t1;
|
||||||
DROP TABLE t1;
|
DROP TABLE t1;
|
||||||
|
|
||||||
|
explain extended select md5('hello'), sha('abc'), sha1('abc'), soundex(''), 'mood' sounds like 'mud', aes_decrypt(aes_encrypt('abc','1'),'1'),concat('*',space(5),'*'), reverse('abc'), rpad('a',4,'1'), lpad('a',4,'1'), concat_ws(',','',NULL,'a'),make_set(255,_latin2'a',_latin2'b',_latin2'c'),elt(2,1),locate("a","b",2),format(130,10),char(0),conv(130,16,10),hex(130),binary 'HE', export_set(255,_latin2'y',_latin2'n',_latin2' '),FIELD('b' COLLATE latin1_bin,'A','B'),FIND_IN_SET(_latin1'B',_latin1'a,b,c,d'),collation(conv(130,16,10)), coercibility(conv(130,16,10)),length('\n\t\r\b\0\_\%\\'),bit_length('\n\t\r\b\0\_\%\\'),bit_length('\n\t\r\b\0\_\%\\'),concat('monty',' was here ','again'),length('hello'),char(ascii('h')),ord('h'),quote(1/0),crc32("123");
|
||||||
|
@ -17,6 +17,7 @@ select version()>="3.23.29";
|
|||||||
select version()>=_utf8"3.23.29";
|
select version()>=_utf8"3.23.29";
|
||||||
select version()>=_latin1"3.23.29";
|
select version()>=_latin1"3.23.29";
|
||||||
select charset(version());
|
select charset(version());
|
||||||
|
explain extended select database(), user();
|
||||||
|
|
||||||
create table t1 (version char(40)) select database(), user(), version() as 'version';
|
create table t1 (version char(40)) select database(), user(), version() as 'version';
|
||||||
show create table t1;
|
show create table t1;
|
||||||
|
@ -19,13 +19,19 @@ select 'b' between 'a' and 'c', 'B' between 'a' and 'c';
|
|||||||
select 2 in (3,2,5,9,5,1),"monty" in ("david","monty","allan"), 1.2 in (1.4,1.2,1.0);
|
select 2 in (3,2,5,9,5,1),"monty" in ("david","monty","allan"), 1.2 in (1.4,1.2,1.0);
|
||||||
select -1.49 or -1.49,0.6 or 0.6;
|
select -1.49 or -1.49,0.6 or 0.6;
|
||||||
select 3 ^ 11, 1 ^ 1, 1 ^ 0, 1 ^ NULL, NULL ^ 1;
|
select 3 ^ 11, 1 ^ 1, 1 ^ 0, 1 ^ NULL, NULL ^ 1;
|
||||||
|
explain extended select 3 ^ 11, 1 ^ 1, 1 ^ 0, 1 ^ NULL, NULL ^ 1;
|
||||||
select 1 XOR 1, 1 XOR 0, 0 XOR 1, 0 XOR 0, NULL XOR 1, 1 XOR NULL, 0 XOR NULL;
|
select 1 XOR 1, 1 XOR 0, 0 XOR 1, 0 XOR 0, NULL XOR 1, 1 XOR NULL, 0 XOR NULL;
|
||||||
select 10 % 7, 10 mod 7, 10 div 3;
|
select 10 % 7, 10 mod 7, 10 div 3;
|
||||||
|
explain extended select 10 % 7, 10 mod 7, 10 div 3;
|
||||||
select (1 << 64)-1, ((1 << 64)-1) DIV 1, ((1 << 64)-1) DIV 2;
|
select (1 << 64)-1, ((1 << 64)-1) DIV 1, ((1 << 64)-1) DIV 2;
|
||||||
|
explain extended select (1 << 64)-1, ((1 << 64)-1) DIV 1, ((1 << 64)-1) DIV 2;
|
||||||
|
|
||||||
create table t1 (a int);
|
create table t1 (a int);
|
||||||
insert t1 values (1);
|
insert t1 values (1);
|
||||||
select * from t1 where 1 xor 1;
|
select * from t1 where 1 xor 1;
|
||||||
|
explain extended select * from t1 where 1 xor 1;
|
||||||
|
select - a from t1;
|
||||||
|
explain extended select - a from t1;
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
|
||||||
#
|
#
|
||||||
@ -41,6 +47,7 @@ select 1 and 0 or 2, 2 or 1 and 0;
|
|||||||
#
|
#
|
||||||
select _koi8r'a' = _koi8r'A';
|
select _koi8r'a' = _koi8r'A';
|
||||||
select _koi8r'a' = _koi8r'A' COLLATE koi8r_general_ci;
|
select _koi8r'a' = _koi8r'A' COLLATE koi8r_general_ci;
|
||||||
|
explain extended select _koi8r'a' = _koi8r'A' COLLATE koi8r_general_ci;
|
||||||
select _koi8r'a' = _koi8r'A' COLLATE koi8r_bin;
|
select _koi8r'a' = _koi8r'A' COLLATE koi8r_bin;
|
||||||
select _koi8r'a' COLLATE koi8r_general_ci = _koi8r'A';
|
select _koi8r'a' COLLATE koi8r_general_ci = _koi8r'A';
|
||||||
select _koi8r'a' COLLATE koi8r_bin = _koi8r'A';
|
select _koi8r'a' COLLATE koi8r_bin = _koi8r'A';
|
||||||
|
@ -7,6 +7,7 @@ drop table if exists t1,t2,t3;
|
|||||||
|
|
||||||
select from_days(to_days("960101")),to_days(960201)-to_days("19960101"),to_days(date_add(curdate(), interval 1 day))-to_days(curdate()),weekday("1997-11-29");
|
select from_days(to_days("960101")),to_days(960201)-to_days("19960101"),to_days(date_add(curdate(), interval 1 day))-to_days(curdate()),weekday("1997-11-29");
|
||||||
select period_add("9602",-12),period_diff(199505,"9404") ;
|
select period_add("9602",-12),period_diff(199505,"9404") ;
|
||||||
|
|
||||||
select now()-now(),weekday(curdate())-weekday(now()),unix_timestamp()-unix_timestamp(now());
|
select now()-now(),weekday(curdate())-weekday(now()),unix_timestamp()-unix_timestamp(now());
|
||||||
select from_unixtime(unix_timestamp("1994-03-02 10:11:12")),from_unixtime(unix_timestamp("1994-03-02 10:11:12"),"%Y-%m-%d %h:%i:%s"),from_unixtime(unix_timestamp("1994-03-02 10:11:12"))+0;
|
select from_unixtime(unix_timestamp("1994-03-02 10:11:12")),from_unixtime(unix_timestamp("1994-03-02 10:11:12"),"%Y-%m-%d %h:%i:%s"),from_unixtime(unix_timestamp("1994-03-02 10:11:12"))+0;
|
||||||
select sec_to_time(9001),sec_to_time(9001)+0,time_to_sec("15:12:22"),
|
select sec_to_time(9001),sec_to_time(9001)+0,time_to_sec("15:12:22"),
|
||||||
@ -231,3 +232,5 @@ select strcmp(date_format(date_sub(localtimestamp(), interval 3 hour),"%Y-%m-%d"
|
|||||||
select strcmp(date_format(utc_timestamp(),"%T"), utc_time())=0;
|
select strcmp(date_format(utc_timestamp(),"%T"), utc_time())=0;
|
||||||
select strcmp(date_format(utc_timestamp(),"%Y-%m-%d"), utc_date())=0;
|
select strcmp(date_format(utc_timestamp(),"%Y-%m-%d"), utc_date())=0;
|
||||||
select strcmp(concat(utc_date(),' ',utc_time()),utc_timestamp())=0;
|
select strcmp(concat(utc_date(),' ',utc_time()),utc_timestamp())=0;
|
||||||
|
|
||||||
|
explain extended select period_add("9602",-12),period_diff(199505,"9404"),from_days(to_days("960101")),dayofmonth("1997-01-02"), month("1997-01-02"), monthname("1972-03-04"),dayofyear("0000-00-00"),HOUR("1997-03-03 23:03:22"),MINUTE("23:03:22"),SECOND(230322),QUARTER(980303),WEEK("1998-03-03"),yearweek("2000-01-01",1),week(19950101,1),year("98-02-03"),weekday(curdate())-weekday(now()),dayname("1962-03-03"),unix_timestamp(),sec_to_time(time_to_sec("0:30:47")/6.21),curtime(),utc_time(),curdate(),utc_date(),utc_timestamp(),date_format("1997-01-02 03:04:05", "%M %W %D %Y %y %m %d %h %i %s %w"),from_unixtime(unix_timestamp("1994-03-02 10:11:12")),"1997-12-31 23:59:59" + INTERVAL 1 SECOND,"1998-01-01 00:00:00" - INTERVAL 1 SECOND,INTERVAL 1 DAY + "1997-12-31", extract(YEAR FROM "1999-01-02 10:11:12"),date_add("1997-12-31 23:59:59",INTERVAL 1 SECOND);
|
||||||
|
@ -260,7 +260,7 @@ explain select spid,count(*) from t1 where spid between 1 and 2 group by spid;
|
|||||||
explain select spid,count(*) from t1 where spid between 1 and 2 group by spid order by null;
|
explain select spid,count(*) from t1 where spid between 1 and 2 group by spid order by null;
|
||||||
select spid,count(*) from t1 where spid between 1 and 2 group by spid;
|
select spid,count(*) from t1 where spid between 1 and 2 group by spid;
|
||||||
select spid,count(*) from t1 where spid between 1 and 2 group by spid desc;
|
select spid,count(*) from t1 where spid between 1 and 2 group by spid desc;
|
||||||
explain select sql_big_result spid,sum(userid) from t1 group by spid desc;
|
explain extended select sql_big_result spid,sum(userid) from t1 group by spid desc;
|
||||||
explain select sql_big_result spid,sum(userid) from t1 group by spid desc order by null;
|
explain select sql_big_result spid,sum(userid) from t1 group by spid desc order by null;
|
||||||
select sql_big_result spid,sum(userid) from t1 group by spid desc;
|
select sql_big_result spid,sum(userid) from t1 group by spid desc;
|
||||||
explain select sql_big_result score,count(*) from t1 group by score desc;
|
explain select sql_big_result score,count(*) from t1 group by score desc;
|
||||||
|
@ -10,6 +10,7 @@ select count(a) as b from t1 where a=0 having b > 0;
|
|||||||
insert into t1 values (null);
|
insert into t1 values (null);
|
||||||
select count(a) as b from t1 where a=0 having b > 0;
|
select count(a) as b from t1 where a=0 having b > 0;
|
||||||
select count(a) as b from t1 where a=0 having b >=0;
|
select count(a) as b from t1 where a=0 having b >=0;
|
||||||
|
explain extended select count(a) as b from t1 where a=0 having b >=0;
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
|
||||||
#
|
#
|
||||||
|
@ -23,4 +23,6 @@ INSERT t1 SET a=5 ON DUPLICATE KEY UPDATE b=0;
|
|||||||
SELECT * FROM t1;
|
SELECT * FROM t1;
|
||||||
INSERT t1 VALUES (2,1,11), (7,4,40) ON DUPLICATE KEY UPDATE c=c+VALUES(a);
|
INSERT t1 VALUES (2,1,11), (7,4,40) ON DUPLICATE KEY UPDATE c=c+VALUES(a);
|
||||||
SELECT *, VALUES(a) FROM t1;
|
SELECT *, VALUES(a) FROM t1;
|
||||||
|
explain extended SELECT *, VALUES(a) FROM t1;
|
||||||
|
explain extended select * from t1 where values(a);
|
||||||
DROP TABLE t1;
|
DROP TABLE t1;
|
||||||
|
@ -8,6 +8,7 @@ drop table if exists t1;
|
|||||||
#
|
#
|
||||||
|
|
||||||
select null,\N,isnull(null),isnull(1/0),isnull(1/0 = null),ifnull(null,1),ifnull(null,"TRUE"),ifnull("TRUE","ERROR"),1/0 is null,1 is not null;
|
select null,\N,isnull(null),isnull(1/0),isnull(1/0 = null),ifnull(null,1),ifnull(null,"TRUE"),ifnull("TRUE","ERROR"),1/0 is null,1 is not null;
|
||||||
|
explain extended select null,\N,isnull(null),isnull(1/0),isnull(1/0 = null),ifnull(null,1),ifnull(null,"TRUE"),ifnull("TRUE","ERROR"),1/0 is null,1 is not null;
|
||||||
select 1 | NULL,1 & NULL,1+NULL,1-NULL;
|
select 1 | NULL,1 & NULL,1+NULL,1-NULL;
|
||||||
select NULL=NULL,NULL<>NULL,IFNULL(NULL,1.1)+0,IFNULL(NULL,1) | 0;
|
select NULL=NULL,NULL<>NULL,IFNULL(NULL,1.1)+0,IFNULL(NULL,1) | 0;
|
||||||
select strcmp("a",NULL),(1<NULL)+0.0,NULL regexp "a",null like "a%","a%" like null;
|
select strcmp("a",NULL),(1<NULL)+0.0,NULL regexp "a",null like "a%","a%" like null;
|
||||||
@ -15,10 +16,12 @@ select concat("a",NULL),replace(NULL,"a","b"),replace("string","i",NULL),replace
|
|||||||
select repeat("a",0),repeat("ab",5+5),repeat("ab",-1),reverse(NULL);
|
select repeat("a",0),repeat("ab",5+5),repeat("ab",-1),reverse(NULL);
|
||||||
select field(NULL,"a","b","c");
|
select field(NULL,"a","b","c");
|
||||||
select 2 between null and 1,2 between 3 AND NULL,NULL between 1 and 2,2 between NULL and 3, 2 between 1 AND null;
|
select 2 between null and 1,2 between 3 AND NULL,NULL between 1 and 2,2 between NULL and 3, 2 between 1 AND null;
|
||||||
|
explain extended select 2 between null and 1,2 between 3 AND NULL,NULL between 1 and 2,2 between NULL and 3, 2 between 1 AND null;
|
||||||
SELECT NULL AND NULL, 1 AND NULL, NULL AND 1, NULL OR NULL, 0 OR NULL, NULL OR 0;
|
SELECT NULL AND NULL, 1 AND NULL, NULL AND 1, NULL OR NULL, 0 OR NULL, NULL OR 0;
|
||||||
SELECT (NULL OR NULL) IS NULL;
|
SELECT (NULL OR NULL) IS NULL;
|
||||||
select NULL AND 0, 0 and NULL;
|
select NULL AND 0, 0 and NULL;
|
||||||
select inet_ntoa(null),inet_aton(null),inet_aton("122.256"),inet_aton("122.226."),inet_aton("");
|
select inet_ntoa(null),inet_aton(null),inet_aton("122.256"),inet_aton("122.226."),inet_aton("");
|
||||||
|
explain extended select inet_ntoa(null),inet_aton(null),inet_aton("122.256"),inet_aton("122.226."),inet_aton("");
|
||||||
|
|
||||||
create table t1 (x int);
|
create table t1 (x int);
|
||||||
insert into t1 values (null);
|
insert into t1 values (null);
|
||||||
|
@ -32,7 +32,7 @@ select product, sum(profit),avg(profit) from t1 group by product with rollup;
|
|||||||
# Sub totals
|
# Sub totals
|
||||||
select product, country_id , year, sum(profit) from t1 group by product, country_id, year;
|
select product, country_id , year, sum(profit) from t1 group by product, country_id, year;
|
||||||
select product, country_id , year, sum(profit) from t1 group by product, country_id, year with rollup;
|
select product, country_id , year, sum(profit) from t1 group by product, country_id, year with rollup;
|
||||||
explain select product, country_id , year, sum(profit) from t1 group by product, country_id, year with rollup;
|
explain extended select product, country_id , year, sum(profit) from t1 group by product, country_id, year with rollup;
|
||||||
select product, country_id , sum(profit) from t1 group by product desc, country_id with rollup;
|
select product, country_id , sum(profit) from t1 group by product desc, country_id with rollup;
|
||||||
|
|
||||||
# limit
|
# limit
|
||||||
|
@ -184,6 +184,7 @@ select RAND() from t1;
|
|||||||
select UNIX_TIMESTAMP() from t1;
|
select UNIX_TIMESTAMP() from t1;
|
||||||
select USER() from t1;
|
select USER() from t1;
|
||||||
select benchmark(1,1) from t1;
|
select benchmark(1,1) from t1;
|
||||||
|
explain extended select benchmark(1,1) from t1;
|
||||||
show status like "Qcache_queries_in_cache";
|
show status like "Qcache_queries_in_cache";
|
||||||
#
|
#
|
||||||
# Tests when the cache is filled
|
# Tests when the cache is filled
|
||||||
|
@ -18,6 +18,7 @@ select (1,2,(3,4)) IN ((3,2,(3,4)), (1,2,(3,4)));
|
|||||||
-- error 1240
|
-- error 1240
|
||||||
select row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,4));
|
select row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,4));
|
||||||
select row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,row(3,NULL)));
|
select row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,row(3,NULL)));
|
||||||
|
explain extended select row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,row(3,NULL)));
|
||||||
|
|
||||||
SELECT (1,2,3)=(0,NULL,3);
|
SELECT (1,2,3)=(0,NULL,3);
|
||||||
SELECT (1,2,3)=(1,NULL,3);
|
SELECT (1,2,3)=(1,NULL,3);
|
||||||
|
@ -62,10 +62,12 @@ enable_query_log;
|
|||||||
# Try to cause a large relay log lag on the slave
|
# Try to cause a large relay log lag on the slave
|
||||||
connection slave;
|
connection slave;
|
||||||
select get_lock("hold_slave",10);
|
select get_lock("hold_slave",10);
|
||||||
|
explain extended select get_lock("hold_slave",10);
|
||||||
start slave;
|
start slave;
|
||||||
#hope this is long enough for I/O thread to fetch over 16K relay log data
|
#hope this is long enough for I/O thread to fetch over 16K relay log data
|
||||||
sleep 3;
|
sleep 3;
|
||||||
select release_lock("hold_slave");
|
select release_lock("hold_slave");
|
||||||
|
explain extended select release_lock("hold_slave");
|
||||||
unlock tables;
|
unlock tables;
|
||||||
|
|
||||||
connection master;
|
connection master;
|
||||||
|
@ -5,6 +5,7 @@ insert into t1 values(get_lock("lock",2));
|
|||||||
dirty_close master;
|
dirty_close master;
|
||||||
connection master1;
|
connection master1;
|
||||||
select get_lock("lock",2);
|
select get_lock("lock",2);
|
||||||
|
|
||||||
select release_lock("lock");
|
select release_lock("lock");
|
||||||
#ignore
|
#ignore
|
||||||
disable_query_log;
|
disable_query_log;
|
||||||
@ -21,7 +22,8 @@ connection slave;
|
|||||||
sync_with_master;
|
sync_with_master;
|
||||||
select get_lock("lock",3);
|
select get_lock("lock",3);
|
||||||
select * from t1;
|
select * from t1;
|
||||||
select is_free_lock("lock");
|
select is_free_lock("lock"), is_used_lock("lock");
|
||||||
|
explain extended select is_free_lock("lock"), is_used_lock("lock");
|
||||||
# Check lock functions
|
# Check lock functions
|
||||||
select is_free_lock("lock2");
|
select is_free_lock("lock2");
|
||||||
select is_free_lock(NULL);
|
select is_free_lock(NULL);
|
||||||
|
@ -7,6 +7,7 @@ sync_with_master;
|
|||||||
# Ask for a master log that has certainly not been reached yet
|
# Ask for a master log that has certainly not been reached yet
|
||||||
# timeout= 2 seconds
|
# timeout= 2 seconds
|
||||||
select master_pos_wait('master-bin.999999',0,2);
|
select master_pos_wait('master-bin.999999',0,2);
|
||||||
|
explain extended select master_pos_wait('master-bin.999999',0,2);
|
||||||
# Testcase for bug 651 (master_pos_wait() hangs if slave idle and STOP SLAVE).
|
# Testcase for bug 651 (master_pos_wait() hangs if slave idle and STOP SLAVE).
|
||||||
send select master_pos_wait('master-bin.999999',0);
|
send select master_pos_wait('master-bin.999999',0);
|
||||||
connection slave1;
|
connection slave1;
|
||||||
|
@ -1596,6 +1596,7 @@ select count(*) from t1;
|
|||||||
select companynr,count(*),sum(fld1) from t2 group by companynr;
|
select companynr,count(*),sum(fld1) from t2 group by companynr;
|
||||||
select companynr,count(*) from t2 group by companynr order by companynr desc limit 5;
|
select companynr,count(*) from t2 group by companynr order by companynr desc limit 5;
|
||||||
select count(*),min(fld4),max(fld4),sum(fld1),avg(fld1),std(fld1),variance(fld1) from t2 where companynr = 34 and fld4<>"";
|
select count(*),min(fld4),max(fld4),sum(fld1),avg(fld1),std(fld1),variance(fld1) from t2 where companynr = 34 and fld4<>"";
|
||||||
|
explain extended select count(*),min(fld4),max(fld4),sum(fld1),avg(fld1),std(fld1),variance(fld1) from t2 where companynr = 34 and fld4<>"";
|
||||||
select companynr,count(*),min(fld4),max(fld4),sum(fld1),avg(fld1),std(fld1),variance(fld1) from t2 group by companynr limit 3;
|
select companynr,count(*),min(fld4),max(fld4),sum(fld1),avg(fld1),std(fld1),variance(fld1) from t2 group by companynr limit 3;
|
||||||
select companynr,t2nr,count(price),sum(price),min(price),max(price),avg(price) from t3 where companynr = 37 group by companynr,t2nr limit 10;
|
select companynr,t2nr,count(price),sum(price),min(price),max(price),avg(price) from t3 where companynr = 37 group by companynr,t2nr limit 10;
|
||||||
select /*! SQL_SMALL_RESULT */ companynr,t2nr,count(price),sum(price),min(price),max(price),avg(price) from t3 where companynr = 37 group by companynr,t2nr limit 10;
|
select /*! SQL_SMALL_RESULT */ companynr,t2nr,count(price),sum(price),min(price),max(price),avg(price) from t3 where companynr = 37 group by companynr,t2nr limit 10;
|
||||||
|
@ -298,6 +298,10 @@ select
|
|||||||
charset(load_file('../../std_data/words.dat')),
|
charset(load_file('../../std_data/words.dat')),
|
||||||
collation(load_file('../../std_data/words.dat')),
|
collation(load_file('../../std_data/words.dat')),
|
||||||
coercibility(load_file('../../std_data/words.dat'));
|
coercibility(load_file('../../std_data/words.dat'));
|
||||||
|
explain extended select
|
||||||
|
charset(load_file('../../std_data/words.dat')),
|
||||||
|
collation(load_file('../../std_data/words.dat')),
|
||||||
|
coercibility(load_file('../../std_data/words.dat'));
|
||||||
update t1 set imagem=load_file('../../std_data/words.dat') where id=1;
|
update t1 set imagem=load_file('../../std_data/words.dat') where id=1;
|
||||||
select if(imagem is null, "ERROR", "OK"),length(imagem) from t1 where id = 1;
|
select if(imagem is null, "ERROR", "OK"),length(imagem) from t1 where id = 1;
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
@ -18,7 +18,7 @@ select x'31',X'ffff'+0;
|
|||||||
create table t1 (ID int(8) unsigned zerofill not null auto_increment,UNIQ bigint(21) unsigned zerofill not null,primary key (ID),unique (UNIQ) );
|
create table t1 (ID int(8) unsigned zerofill not null auto_increment,UNIQ bigint(21) unsigned zerofill not null,primary key (ID),unique (UNIQ) );
|
||||||
insert into t1 set UNIQ=0x38afba1d73e6a18a;
|
insert into t1 set UNIQ=0x38afba1d73e6a18a;
|
||||||
insert into t1 set UNIQ=123;
|
insert into t1 set UNIQ=123;
|
||||||
explain select * from t1 where UNIQ=0x38afba1d73e6a18a;
|
explain extended select * from t1 where UNIQ=0x38afba1d73e6a18a;
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
|
||||||
#
|
#
|
||||||
|
@ -16,6 +16,7 @@ select @test_int,@test_double,@test_string,@test_string2;
|
|||||||
set @test_int=null,@test_double=null,@test_string=null,@test_string2=null;
|
set @test_int=null,@test_double=null,@test_string=null,@test_string2=null;
|
||||||
select @test_int,@test_double,@test_string,@test_string2;
|
select @test_int,@test_double,@test_string,@test_string2;
|
||||||
select @t1:=(@t2:=1)+@t3:=4,@t1,@t2,@t3;
|
select @t1:=(@t2:=1)+@t3:=4,@t1,@t2,@t3;
|
||||||
|
explain extended select @t1:=(@t2:=1)+@t3:=4,@t1,@t2,@t3;
|
||||||
select @t5;
|
select @t5;
|
||||||
|
|
||||||
#
|
#
|
||||||
@ -52,7 +53,9 @@ select @@local.max_join_size, @@global.max_join_size;
|
|||||||
select @@identity, length(@@version)>0;
|
select @@identity, length(@@version)>0;
|
||||||
select @@VERSION=version();
|
select @@VERSION=version();
|
||||||
select last_insert_id(345);
|
select last_insert_id(345);
|
||||||
|
explain extended select last_insert_id(345);
|
||||||
select @@IDENTITY,last_insert_id(), @@identity;
|
select @@IDENTITY,last_insert_id(), @@identity;
|
||||||
|
explain extended select @@IDENTITY,last_insert_id(), @@identity;
|
||||||
|
|
||||||
set big_tables=OFF, big_tables=ON, big_tables=0, big_tables=1, big_tables="OFF", big_tables="ON";
|
set big_tables=OFF, big_tables=ON, big_tables=0, big_tables=1, big_tables="OFF", big_tables="ON";
|
||||||
|
|
||||||
|
61
sql/item.cc
61
sql/item.cc
@ -93,7 +93,7 @@ void Item::print_item_w_name(String *str)
|
|||||||
print(str);
|
print(str);
|
||||||
if (name)
|
if (name)
|
||||||
{
|
{
|
||||||
str->append(" AS `");
|
str->append(" AS `", 5);
|
||||||
str->append(name);
|
str->append(name);
|
||||||
str->append('`');
|
str->append('`');
|
||||||
}
|
}
|
||||||
@ -435,6 +435,7 @@ bool Item_field::eq(const Item *item, bool binary_cmp) const
|
|||||||
db_name))))));
|
db_name))))));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
table_map Item_field::used_tables() const
|
table_map Item_field::used_tables() const
|
||||||
{
|
{
|
||||||
if (field->table->const_table)
|
if (field->table->const_table)
|
||||||
@ -442,6 +443,7 @@ table_map Item_field::used_tables() const
|
|||||||
return (depended_from ? OUTER_REF_TABLE_BIT : field->table->map);
|
return (depended_from ? OUTER_REF_TABLE_BIT : field->table->map);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Item *Item_field::get_tmp_table_item(THD *thd)
|
Item *Item_field::get_tmp_table_item(THD *thd)
|
||||||
{
|
{
|
||||||
Item_field *new_item= new Item_field(thd, *this);
|
Item_field *new_item= new Item_field(thd, *this);
|
||||||
@ -450,6 +452,7 @@ Item *Item_field::get_tmp_table_item(THD *thd)
|
|||||||
return new_item;
|
return new_item;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
String *Item_int::val_str(String *str)
|
String *Item_int::val_str(String *str)
|
||||||
{
|
{
|
||||||
str->set(value, default_charset());
|
str->set(value, default_charset());
|
||||||
@ -458,18 +461,22 @@ String *Item_int::val_str(String *str)
|
|||||||
|
|
||||||
void Item_int::print(String *str)
|
void Item_int::print(String *str)
|
||||||
{
|
{
|
||||||
str_value.set(value, default_charset());
|
// latin1 is good enough for numbers
|
||||||
|
str_value.set(value, &my_charset_latin1);
|
||||||
str->append(str_value);
|
str->append(str_value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
String *Item_uint::val_str(String *str)
|
String *Item_uint::val_str(String *str)
|
||||||
{
|
{
|
||||||
str->set((ulonglong) value, default_charset());
|
str->set((ulonglong) value, default_charset());
|
||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Item_uint::print(String *str)
|
void Item_uint::print(String *str)
|
||||||
{
|
{
|
||||||
|
// latin1 is good enough for numbers
|
||||||
str_value.set((ulonglong) value, default_charset());
|
str_value.set((ulonglong) value, default_charset());
|
||||||
str->append(str_value);
|
str->append(str_value);
|
||||||
}
|
}
|
||||||
@ -481,12 +488,46 @@ String *Item_real::val_str(String *str)
|
|||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Item_string::print(String *str)
|
void Item_string::print(String *str)
|
||||||
{
|
{
|
||||||
str->append('_');
|
str->append('_');
|
||||||
str->append(collation.collation->csname);
|
str->append(collation.collation->csname);
|
||||||
str->append('\'');
|
str->append('\'');
|
||||||
str->append(str_value);
|
char *st= (char*)str_value.ptr(), *end= st+str_value.length();
|
||||||
|
for(; st < end; st++)
|
||||||
|
{
|
||||||
|
uchar c= *st;
|
||||||
|
switch (c)
|
||||||
|
{
|
||||||
|
case '\\':
|
||||||
|
str->append("\\\\", 2);
|
||||||
|
break;
|
||||||
|
case '\0':
|
||||||
|
str->append("\\0", 2);
|
||||||
|
break;
|
||||||
|
case '\'':
|
||||||
|
str->append("\\'", 2);
|
||||||
|
break;
|
||||||
|
case '\n':
|
||||||
|
str->append("\\n", 2);
|
||||||
|
break;
|
||||||
|
case '\r':
|
||||||
|
str->append("\\r", 2);
|
||||||
|
break;
|
||||||
|
case '\t':
|
||||||
|
str->append("\\t", 2);
|
||||||
|
break;
|
||||||
|
case '\b':
|
||||||
|
str->append("\\b", 2);
|
||||||
|
break;
|
||||||
|
case 26: //Ctrl-Z
|
||||||
|
str->append("\\z", 2);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
str->append(c);
|
||||||
|
}
|
||||||
|
}
|
||||||
str->append('\'');
|
str->append('\'');
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -707,7 +748,7 @@ String *Item_param::query_val_str(String* str)
|
|||||||
make_datetime(str, <ime, is_time_only, 0,
|
make_datetime(str, <ime, is_time_only, 0,
|
||||||
tmp_format->format, tmp_format->format_length, 0);
|
tmp_format->format, tmp_format->format_length, 0);
|
||||||
}
|
}
|
||||||
str->append("'");
|
str->append('\'');
|
||||||
}
|
}
|
||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
@ -1551,7 +1592,7 @@ void Item_ref::print(String *str)
|
|||||||
|
|
||||||
void Item_ref_null_helper::print(String *str)
|
void Item_ref_null_helper::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("<ref_null_helper>(");
|
str->append("<ref_null_helper>(", 18);
|
||||||
if (ref && *ref)
|
if (ref && *ref)
|
||||||
(*ref)->print(str);
|
(*ref)->print(str);
|
||||||
else
|
else
|
||||||
@ -1562,7 +1603,7 @@ void Item_ref_null_helper::print(String *str)
|
|||||||
|
|
||||||
void Item_null_helper::print(String *str)
|
void Item_null_helper::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("<null_helper>(");
|
str->append("<null_helper>(", 14);
|
||||||
store->print(str);
|
store->print(str);
|
||||||
str->append(')');
|
str->append(')');
|
||||||
}
|
}
|
||||||
@ -1609,10 +1650,10 @@ void Item_default_value::print(String *str)
|
|||||||
{
|
{
|
||||||
if (!arg)
|
if (!arg)
|
||||||
{
|
{
|
||||||
str->append("DEFAULT");
|
str->append("default", 6);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
str->append("DEFAULT(");
|
str->append("default", 7);
|
||||||
arg->print(str);
|
arg->print(str);
|
||||||
str->append(')');
|
str->append(')');
|
||||||
}
|
}
|
||||||
@ -1665,7 +1706,7 @@ bool Item_insert_value::fix_fields(THD *thd, struct st_table_list *table_list, I
|
|||||||
|
|
||||||
void Item_insert_value::print(String *str)
|
void Item_insert_value::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("VALUE(");
|
str->append("values(", 7);
|
||||||
arg->print(str);
|
arg->print(str);
|
||||||
str->append(')');
|
str->append(')');
|
||||||
}
|
}
|
||||||
@ -1792,7 +1833,7 @@ Item_cache* Item_cache::get_cache(Item_result type)
|
|||||||
|
|
||||||
void Item_cache::print(String *str)
|
void Item_cache::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("<cache>(");
|
str->append("<cache>(", 8);
|
||||||
if (example)
|
if (example)
|
||||||
example->print(str);
|
example->print(str);
|
||||||
else
|
else
|
||||||
|
@ -316,7 +316,7 @@ public:
|
|||||||
bool basic_const_item() const { return 1; }
|
bool basic_const_item() const { return 1; }
|
||||||
Item *new_item() { return new Item_null(name); }
|
Item *new_item() { return new Item_null(name); }
|
||||||
bool is_null() { return 1; }
|
bool is_null() { return 1; }
|
||||||
void print(String *str) { str->append("NULL"); }
|
void print(String *str) { str->append("NULL", 4); }
|
||||||
};
|
};
|
||||||
|
|
||||||
class Item_param :public Item
|
class Item_param :public Item
|
||||||
|
@ -717,9 +717,9 @@ void Item_func_between::print(String *str)
|
|||||||
{
|
{
|
||||||
str->append('(');
|
str->append('(');
|
||||||
args[0]->print(str);
|
args[0]->print(str);
|
||||||
str->append(" between ");
|
str->append(" between ", 9);
|
||||||
args[1]->print(str);
|
args[1]->print(str);
|
||||||
str->append(" and ");
|
str->append(" and ", 5);
|
||||||
args[2]->print(str);
|
args[2]->print(str);
|
||||||
str->append(')');
|
str->append(')');
|
||||||
}
|
}
|
||||||
@ -880,7 +880,7 @@ Item_func_nullif::fix_length_and_dec()
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
nullif () returns NULL if arguments are different, else it returns the
|
nullif () returns NULL if arguments are equal, else it returns the
|
||||||
first argument.
|
first argument.
|
||||||
Note that we have to evaluate the first argument twice as the compare
|
Note that we have to evaluate the first argument twice as the compare
|
||||||
may have been done with a different type than return value
|
may have been done with a different type than return value
|
||||||
@ -1117,7 +1117,7 @@ void Item_func_case::fix_length_and_dec()
|
|||||||
|
|
||||||
void Item_func_case::print(String *str)
|
void Item_func_case::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("(case ");
|
str->append("(case ", 6);
|
||||||
if (first_expr_num != -1)
|
if (first_expr_num != -1)
|
||||||
{
|
{
|
||||||
args[first_expr_num]->print(str);
|
args[first_expr_num]->print(str);
|
||||||
@ -1125,19 +1125,19 @@ void Item_func_case::print(String *str)
|
|||||||
}
|
}
|
||||||
for (uint i=0 ; i < ncases ; i+=2)
|
for (uint i=0 ; i < ncases ; i+=2)
|
||||||
{
|
{
|
||||||
str->append("when ");
|
str->append("when ", 5);
|
||||||
args[i]->print(str);
|
args[i]->print(str);
|
||||||
str->append(" then ");
|
str->append(" then ", 6);
|
||||||
args[i+1]->print(str);
|
args[i+1]->print(str);
|
||||||
str->append(' ');
|
str->append(' ');
|
||||||
}
|
}
|
||||||
if (else_expr_num != -1)
|
if (else_expr_num != -1)
|
||||||
{
|
{
|
||||||
str->append("else ");
|
str->append("else ", 5);
|
||||||
args[else_expr_num]->print(str);
|
args[else_expr_num]->print(str);
|
||||||
str->append(' ');
|
str->append(' ');
|
||||||
}
|
}
|
||||||
str->append("end)");
|
str->append("end)", 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1545,14 +1545,14 @@ void Item_func_in::print(String *str)
|
|||||||
{
|
{
|
||||||
str->append('(');
|
str->append('(');
|
||||||
args[0]->print(str);
|
args[0]->print(str);
|
||||||
str->append(" IN (");
|
str->append(" in (", 5);
|
||||||
for (uint i=1 ; i < arg_count ; i++)
|
for (uint i=1 ; i < arg_count ; i++)
|
||||||
{
|
{
|
||||||
if (i > 1)
|
if (i > 1)
|
||||||
str->append(',');
|
str->append(',');
|
||||||
args[i]->print(str);
|
args[i]->print(str);
|
||||||
}
|
}
|
||||||
str->append("))");
|
str->append("))", 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1924,7 +1924,7 @@ void Item_func_isnotnull::print(String *str)
|
|||||||
{
|
{
|
||||||
str->append('(');
|
str->append('(');
|
||||||
args[0]->print(str);
|
args[0]->print(str);
|
||||||
str->append(" is not null)");
|
str->append(" is not null)", 13);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -349,6 +349,7 @@ public:
|
|||||||
enum Item_result result_type () const { return cached_result_type; }
|
enum Item_result result_type () const { return cached_result_type; }
|
||||||
void fix_length_and_dec();
|
void fix_length_and_dec();
|
||||||
const char *func_name() const { return "nullif"; }
|
const char *func_name() const { return "nullif"; }
|
||||||
|
void print(String *str) { Item_func::print(str); }
|
||||||
table_map not_null_tables() const { return 0; }
|
table_map not_null_tables() const { return 0; }
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -780,7 +781,7 @@ public:
|
|||||||
~Item_func_regex();
|
~Item_func_regex();
|
||||||
longlong val_int();
|
longlong val_int();
|
||||||
bool fix_fields(THD *thd, struct st_table_list *tlist, Item **ref);
|
bool fix_fields(THD *thd, struct st_table_list *tlist, Item **ref);
|
||||||
const char *func_name() const { return "regex"; }
|
const char *func_name() const { return "regexp"; }
|
||||||
void print(String *str) { print_op(str); }
|
void print(String *str) { print_op(str); }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -292,7 +292,7 @@ Item *create_func_period_diff(Item* a, Item *b)
|
|||||||
|
|
||||||
Item *create_func_pi(void)
|
Item *create_func_pi(void)
|
||||||
{
|
{
|
||||||
return new Item_real(NullS,M_PI,6,8);
|
return new Item_real("Pi()",M_PI,6,8);
|
||||||
}
|
}
|
||||||
|
|
||||||
Item *create_func_pow(Item* a, Item *b)
|
Item *create_func_pow(Item* a, Item *b)
|
||||||
|
@ -287,13 +287,19 @@ void Item_func::print(String *str)
|
|||||||
{
|
{
|
||||||
str->append(func_name());
|
str->append(func_name());
|
||||||
str->append('(');
|
str->append('(');
|
||||||
|
print_args(str);
|
||||||
|
str->append(')');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Item_func::print_args(String *str)
|
||||||
|
{
|
||||||
for (uint i=0 ; i < arg_count ; i++)
|
for (uint i=0 ; i < arg_count ; i++)
|
||||||
{
|
{
|
||||||
if (i)
|
if (i)
|
||||||
str->append(',');
|
str->append(',');
|
||||||
args[i]->print(str);
|
args[i]->print(str);
|
||||||
}
|
}
|
||||||
str->append(')');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -464,18 +470,18 @@ String *Item_num_op::val_str(String *str)
|
|||||||
|
|
||||||
void Item_func_signed::print(String *str)
|
void Item_func_signed::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("cast(");
|
str->append("cast(", 5);
|
||||||
args[0]->print(str);
|
args[0]->print(str);
|
||||||
str->append("as signed)");
|
str->append(" as signed)", 11);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Item_func_unsigned::print(String *str)
|
void Item_func_unsigned::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("cast(");
|
str->append("cast(", 5);
|
||||||
args[0]->print(str);
|
args[0]->print(str);
|
||||||
str->append("as unsigned)");
|
str->append(" as unsigned)", 13);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1202,6 +1208,21 @@ longlong Item_func_locate::val_int()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Item_func_locate::print(String *str)
|
||||||
|
{
|
||||||
|
str->append("locate(", 7);
|
||||||
|
args[1]->print(str);
|
||||||
|
str->append(',');
|
||||||
|
args[0]->print(str);
|
||||||
|
if (arg_count == 3)
|
||||||
|
{
|
||||||
|
str->append(',');
|
||||||
|
args[2]->print(str);
|
||||||
|
}
|
||||||
|
str->append(')');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
longlong Item_func_field::val_int()
|
longlong Item_func_field::val_int()
|
||||||
{
|
{
|
||||||
if (cmp_type == STRING_RESULT)
|
if (cmp_type == STRING_RESULT)
|
||||||
@ -1782,7 +1803,7 @@ void item_user_lock_release(ULL *ull)
|
|||||||
String tmp(buf,sizeof(buf), system_charset_info);
|
String tmp(buf,sizeof(buf), system_charset_info);
|
||||||
tmp.copy(command, strlen(command), tmp.charset());
|
tmp.copy(command, strlen(command), tmp.charset());
|
||||||
tmp.append(ull->key,ull->key_length);
|
tmp.append(ull->key,ull->key_length);
|
||||||
tmp.append("\")");
|
tmp.append("\")", 2);
|
||||||
Query_log_event qev(current_thd, tmp.ptr(), tmp.length(),1);
|
Query_log_event qev(current_thd, tmp.ptr(), tmp.length(),1);
|
||||||
qev.error_code=0; // this query is always safe to run on slave
|
qev.error_code=0; // this query is always safe to run on slave
|
||||||
mysql_bin_log.write(&qev);
|
mysql_bin_log.write(&qev);
|
||||||
@ -2067,6 +2088,19 @@ longlong Item_func_benchmark::val_int()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Item_func_benchmark::print(String *str)
|
||||||
|
{
|
||||||
|
str->append("benchmark(", 10);
|
||||||
|
char buffer[20];
|
||||||
|
// latin1 is good enough for numbers
|
||||||
|
String st(buffer, sizeof(buffer), &my_charset_latin1);
|
||||||
|
st.set((ulonglong)loop_count, &my_charset_latin1);
|
||||||
|
str->append(st);
|
||||||
|
str->append(',');
|
||||||
|
args[0]->print(str);
|
||||||
|
str->append(')');
|
||||||
|
}
|
||||||
|
|
||||||
#define extra_size sizeof(double)
|
#define extra_size sizeof(double)
|
||||||
|
|
||||||
static user_var_entry *get_variable(HASH *hash, LEX_STRING &name,
|
static user_var_entry *get_variable(HASH *hash, LEX_STRING &name,
|
||||||
@ -2405,9 +2439,9 @@ String *Item_func_set_user_var::val_str(String *str)
|
|||||||
|
|
||||||
void Item_func_set_user_var::print(String *str)
|
void Item_func_set_user_var::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("(@@",3);
|
str->append("(@", 2);
|
||||||
str->append(name.str,name.length);
|
str->append(name.str, name.length);
|
||||||
str->append(":=",2);
|
str->append(":=", 2);
|
||||||
args[0]->print(str);
|
args[0]->print(str);
|
||||||
str->append(')');
|
str->append(')');
|
||||||
}
|
}
|
||||||
@ -2553,7 +2587,7 @@ enum Item_result Item_func_get_user_var::result_type() const
|
|||||||
|
|
||||||
void Item_func_get_user_var::print(String *str)
|
void Item_func_get_user_var::print(String *str)
|
||||||
{
|
{
|
||||||
str->append('@');
|
str->append("(@", 2);
|
||||||
str->append(name.str,name.length);
|
str->append(name.str,name.length);
|
||||||
str->append(')');
|
str->append(')');
|
||||||
}
|
}
|
||||||
@ -2840,7 +2874,7 @@ double Item_func_match::val()
|
|||||||
|
|
||||||
void Item_func_match::print(String *str)
|
void Item_func_match::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("(match ");
|
str->append("(match ", 7);
|
||||||
List_iterator_fast<Item> li(fields);
|
List_iterator_fast<Item> li(fields);
|
||||||
Item *item;
|
Item *item;
|
||||||
bool first= 1;
|
bool first= 1;
|
||||||
@ -2852,11 +2886,11 @@ void Item_func_match::print(String *str)
|
|||||||
str->append(',');
|
str->append(',');
|
||||||
item->print(str);
|
item->print(str);
|
||||||
}
|
}
|
||||||
str->append(" against (");
|
str->append(" against (", 10);
|
||||||
args[0]->print(str);
|
args[0]->print(str);
|
||||||
if (mode == FT_BOOL)
|
if (mode == FT_BOOL)
|
||||||
str->append(" in boolean mode");
|
str->append(" in boolean mode", 16);
|
||||||
str->append("))");
|
str->append("))", 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
longlong Item_func_bit_xor::val_int()
|
longlong Item_func_bit_xor::val_int()
|
||||||
|
@ -124,6 +124,7 @@ public:
|
|||||||
virtual void split_sum_func(Item **ref_pointer_array, List<Item> &fields);
|
virtual void split_sum_func(Item **ref_pointer_array, List<Item> &fields);
|
||||||
void print(String *str);
|
void print(String *str);
|
||||||
void print_op(String *str);
|
void print_op(String *str);
|
||||||
|
void print_args(String *str);
|
||||||
void fix_num_length_and_dec();
|
void fix_num_length_and_dec();
|
||||||
inline bool get_arg0_date(TIME *ltime,bool fuzzy_date)
|
inline bool get_arg0_date(TIME *ltime,bool fuzzy_date)
|
||||||
{
|
{
|
||||||
@ -608,6 +609,7 @@ public:
|
|||||||
const char *func_name() const { return "locate"; }
|
const char *func_name() const { return "locate"; }
|
||||||
longlong val_int();
|
longlong val_int();
|
||||||
void fix_length_and_dec();
|
void fix_length_and_dec();
|
||||||
|
void print(String *str);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -733,6 +735,7 @@ class Item_func_benchmark :public Item_int_func
|
|||||||
longlong val_int();
|
longlong val_int();
|
||||||
const char *func_name() const { return "benchmark"; }
|
const char *func_name() const { return "benchmark"; }
|
||||||
void fix_length_and_dec() { max_length=1; maybe_null=0; }
|
void fix_length_and_dec() { max_length=1; maybe_null=0; }
|
||||||
|
void print(String *str);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -1056,7 +1059,7 @@ class Item_func_is_free_lock :public Item_int_func
|
|||||||
public:
|
public:
|
||||||
Item_func_is_free_lock(Item *a) :Item_int_func(a) {}
|
Item_func_is_free_lock(Item *a) :Item_int_func(a) {}
|
||||||
longlong val_int();
|
longlong val_int();
|
||||||
const char *func_name() const { return "check_lock"; }
|
const char *func_name() const { return "is_free_lock"; }
|
||||||
void fix_length_and_dec() { decimals=0; max_length=1; maybe_null=1;}
|
void fix_length_and_dec() { decimals=0; max_length=1; maybe_null=1;}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -654,6 +654,17 @@ void Item_func_concat_ws::update_used_tables()
|
|||||||
const_item_cache&=separator->const_item();
|
const_item_cache&=separator->const_item();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Item_func_concat_ws::print(String *str)
|
||||||
|
{
|
||||||
|
str->append("concat_ws(", 10);
|
||||||
|
separator->print(str);
|
||||||
|
if (arg_count)
|
||||||
|
{
|
||||||
|
str->append(',');
|
||||||
|
print_args(str);
|
||||||
|
}
|
||||||
|
str->append(')');
|
||||||
|
}
|
||||||
|
|
||||||
String *Item_func_reverse::val_str(String *str)
|
String *Item_func_reverse::val_str(String *str)
|
||||||
{
|
{
|
||||||
@ -1613,6 +1624,19 @@ String *Item_func_format::val_str(String *str)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Item_func_format::print(String *str)
|
||||||
|
{
|
||||||
|
str->append("format(", 7);
|
||||||
|
args[0]->print(str);
|
||||||
|
str->append(',');
|
||||||
|
// latin1 is good enough for numbers
|
||||||
|
char buffer[20];
|
||||||
|
String st(buffer, sizeof(buffer), &my_charset_latin1);
|
||||||
|
st.set((ulonglong)decimals, &my_charset_latin1);
|
||||||
|
str->append(st);
|
||||||
|
str->append(')');
|
||||||
|
}
|
||||||
|
|
||||||
void Item_func_elt::fix_length_and_dec()
|
void Item_func_elt::fix_length_and_dec()
|
||||||
{
|
{
|
||||||
max_length=0;
|
max_length=0;
|
||||||
@ -1764,6 +1788,19 @@ String *Item_func_make_set::val_str(String *str)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Item_func_make_set::print(String *str)
|
||||||
|
{
|
||||||
|
str->append("make_set(", 9);
|
||||||
|
item->print(str);
|
||||||
|
if (arg_count)
|
||||||
|
{
|
||||||
|
str->append(',');
|
||||||
|
print_args(str);
|
||||||
|
}
|
||||||
|
str->append(')');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
String *Item_func_char::val_str(String *str)
|
String *Item_func_char::val_str(String *str)
|
||||||
{
|
{
|
||||||
str->length(0);
|
str->length(0);
|
||||||
@ -2077,7 +2114,14 @@ void Item_func_conv_charset::fix_length_and_dec()
|
|||||||
max_length = args[0]->max_length*conv_charset->mbmaxlen;
|
max_length = args[0]->max_length*conv_charset->mbmaxlen;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Item_func_conv_charset::print(String *str)
|
||||||
|
{
|
||||||
|
str->append("convert(", 8);
|
||||||
|
args[0]->print(str);
|
||||||
|
str->append(" using ", 7);
|
||||||
|
str->append(conv_charset->csname);
|
||||||
|
str->append(')');
|
||||||
|
}
|
||||||
|
|
||||||
String *Item_func_conv_charset3::val_str(String *str)
|
String *Item_func_conv_charset3::val_str(String *str)
|
||||||
{
|
{
|
||||||
@ -2273,9 +2317,9 @@ String *Item_func_hex::val_str(String *str)
|
|||||||
|
|
||||||
void Item_func_binary::print(String *str)
|
void Item_func_binary::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("cast(");
|
str->append("cast(", 5);
|
||||||
args[0]->print(str);
|
args[0]->print(str);
|
||||||
str->append("as binary)");
|
str->append(" as binary)", 11);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -112,6 +112,7 @@ public:
|
|||||||
return separator->walk(processor, arg) ||
|
return separator->walk(processor, arg) ||
|
||||||
Item_str_func::walk(processor, arg);
|
Item_str_func::walk(processor, arg);
|
||||||
}
|
}
|
||||||
|
void print(String *str);
|
||||||
};
|
};
|
||||||
|
|
||||||
class Item_func_reverse :public Item_str_func
|
class Item_func_reverse :public Item_str_func
|
||||||
@ -426,6 +427,7 @@ public:
|
|||||||
return item->walk(processor, arg) ||
|
return item->walk(processor, arg) ||
|
||||||
Item_str_func::walk(processor, arg);
|
Item_str_func::walk(processor, arg);
|
||||||
}
|
}
|
||||||
|
void print(String *str);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -441,6 +443,7 @@ public:
|
|||||||
max_length=args[0]->max_length+(args[0]->max_length-args[0]->decimals)/3;
|
max_length=args[0]->max_length+(args[0]->max_length-args[0]->decimals)/3;
|
||||||
}
|
}
|
||||||
const char *func_name() const { return "format"; }
|
const char *func_name() const { return "format"; }
|
||||||
|
void print(String *);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -602,7 +605,8 @@ public:
|
|||||||
{ conv_charset=cs; }
|
{ conv_charset=cs; }
|
||||||
String *val_str(String *);
|
String *val_str(String *);
|
||||||
void fix_length_and_dec();
|
void fix_length_and_dec();
|
||||||
const char *func_name() const { return "conv_charset"; }
|
const char *func_name() const { return "convert"; }
|
||||||
|
void print(String *str);
|
||||||
};
|
};
|
||||||
|
|
||||||
class Item_func_set_collation :public Item_str_func
|
class Item_func_set_collation :public Item_str_func
|
||||||
@ -612,7 +616,8 @@ public:
|
|||||||
String *val_str(String *);
|
String *val_str(String *);
|
||||||
void fix_length_and_dec();
|
void fix_length_and_dec();
|
||||||
bool eq(const Item *item, bool binary_cmp) const;
|
bool eq(const Item *item, bool binary_cmp) const;
|
||||||
const char *func_name() const { return "set_collation"; }
|
const char *func_name() const { return "collate"; }
|
||||||
|
void print(String *str) { print_op(str); }
|
||||||
};
|
};
|
||||||
|
|
||||||
class Item_func_conv_charset3 :public Item_str_func
|
class Item_func_conv_charset3 :public Item_str_func
|
||||||
@ -622,7 +627,7 @@ public:
|
|||||||
:Item_str_func(arg1,arg2,arg3) {}
|
:Item_str_func(arg1,arg2,arg3) {}
|
||||||
String *val_str(String *);
|
String *val_str(String *);
|
||||||
void fix_length_and_dec();
|
void fix_length_and_dec();
|
||||||
const char *func_name() const { return "conv_charset3"; }
|
const char *func_name() const { return "convert"; }
|
||||||
};
|
};
|
||||||
|
|
||||||
class Item_func_charset :public Item_str_func
|
class Item_func_charset :public Item_str_func
|
||||||
|
@ -219,7 +219,7 @@ Item_maxmin_subselect::Item_maxmin_subselect(Item_subselect *parent,
|
|||||||
|
|
||||||
void Item_maxmin_subselect::print(String *str)
|
void Item_maxmin_subselect::print(String *str)
|
||||||
{
|
{
|
||||||
str->append(max?"<max>":"<min>");
|
str->append(max?"<max>":"<min>", 5);
|
||||||
Item_singlerow_subselect::print(str);
|
Item_singlerow_subselect::print(str);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -403,7 +403,7 @@ Item_exists_subselect::Item_exists_subselect(st_select_lex *select_lex):
|
|||||||
|
|
||||||
void Item_exists_subselect::print(String *str)
|
void Item_exists_subselect::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("exists");
|
str->append("exists", 6);
|
||||||
Item_subselect::print(str);
|
Item_subselect::print(str);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -841,11 +841,11 @@ Item_in_subselect::select_transformer(JOIN *join)
|
|||||||
void Item_in_subselect::print(String *str)
|
void Item_in_subselect::print(String *str)
|
||||||
{
|
{
|
||||||
if (transformed)
|
if (transformed)
|
||||||
str->append("<exists>");
|
str->append("<exists>", 8);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
left_expr->print(str);
|
left_expr->print(str);
|
||||||
str->append(" in ");
|
str->append(" in ", 4);
|
||||||
}
|
}
|
||||||
Item_subselect::print(str);
|
Item_subselect::print(str);
|
||||||
}
|
}
|
||||||
@ -864,7 +864,7 @@ Item_allany_subselect::select_transformer(JOIN *join)
|
|||||||
void Item_allany_subselect::print(String *str)
|
void Item_allany_subselect::print(String *str)
|
||||||
{
|
{
|
||||||
if (transformed)
|
if (transformed)
|
||||||
str->append("<exists>");
|
str->append("<exists>", 8);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
left_expr->print(str);
|
left_expr->print(str);
|
||||||
@ -872,22 +872,22 @@ void Item_allany_subselect::print(String *str)
|
|||||||
if (all)
|
if (all)
|
||||||
{
|
{
|
||||||
if (func == &Item_bool_func2::lt_creator)
|
if (func == &Item_bool_func2::lt_creator)
|
||||||
str->append(">=");
|
str->append(">=", 2);
|
||||||
else if (func == &Item_bool_func2::gt_creator)
|
else if (func == &Item_bool_func2::gt_creator)
|
||||||
str->append("<=");
|
str->append("<=", 2);
|
||||||
else if (func == &Item_bool_func2::le_creator)
|
else if (func == &Item_bool_func2::le_creator)
|
||||||
str->append('>');
|
str->append('>');
|
||||||
else if (func == &Item_bool_func2::ge_creator)
|
else if (func == &Item_bool_func2::ge_creator)
|
||||||
str->append('<');
|
str->append('<');
|
||||||
else if (func == &Item_bool_func2::eq_creator)
|
else if (func == &Item_bool_func2::eq_creator)
|
||||||
str->append("<>");
|
str->append("<>", 2);
|
||||||
else if (func == &Item_bool_func2::ne_creator)
|
else if (func == &Item_bool_func2::ne_creator)
|
||||||
str->append('=');
|
str->append('=');
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
DBUG_ASSERT(0); // Impossible
|
DBUG_ASSERT(0); // Impossible
|
||||||
}
|
}
|
||||||
str->append(" all ");
|
str->append(" all ", 5);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -896,18 +896,18 @@ void Item_allany_subselect::print(String *str)
|
|||||||
else if (func == &Item_bool_func2::gt_creator)
|
else if (func == &Item_bool_func2::gt_creator)
|
||||||
str->append('>');
|
str->append('>');
|
||||||
else if (func == &Item_bool_func2::le_creator)
|
else if (func == &Item_bool_func2::le_creator)
|
||||||
str->append("<=");
|
str->append("<=", 2);
|
||||||
else if (func == &Item_bool_func2::ge_creator)
|
else if (func == &Item_bool_func2::ge_creator)
|
||||||
str->append(">=");
|
str->append(">=", 2);
|
||||||
else if (func == &Item_bool_func2::eq_creator)
|
else if (func == &Item_bool_func2::eq_creator)
|
||||||
str->append('=');
|
str->append('=');
|
||||||
else if (func == &Item_bool_func2::ne_creator)
|
else if (func == &Item_bool_func2::ne_creator)
|
||||||
str->append("<>");
|
str->append("<>", 2);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
DBUG_ASSERT(0); // Impossible
|
DBUG_ASSERT(0); // Impossible
|
||||||
}
|
}
|
||||||
str->append(" any ");
|
str->append(" any ", 5);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Item_subselect::print(str);
|
Item_subselect::print(str);
|
||||||
@ -1330,16 +1330,16 @@ void subselect_union_engine::print(String *str)
|
|||||||
|
|
||||||
void subselect_uniquesubquery_engine::print(String *str)
|
void subselect_uniquesubquery_engine::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("<primary_index_lookup>(");
|
str->append("<primary_index_lookup>(", 23);
|
||||||
tab->ref.items[0]->print(str);
|
tab->ref.items[0]->print(str);
|
||||||
str->append(" in ");
|
str->append(" in ", 4);
|
||||||
str->append(tab->table->real_name);
|
str->append(tab->table->real_name);
|
||||||
KEY *key_info= tab->table->key_info+ tab->ref.key;
|
KEY *key_info= tab->table->key_info+ tab->ref.key;
|
||||||
str->append(" on ");
|
str->append(" on ", 4);
|
||||||
str->append(key_info->name);
|
str->append(key_info->name);
|
||||||
if (cond)
|
if (cond)
|
||||||
{
|
{
|
||||||
str->append(" where ");
|
str->append(" where ", 7);
|
||||||
cond->print(str);
|
cond->print(str);
|
||||||
}
|
}
|
||||||
str->append(')');
|
str->append(')');
|
||||||
@ -1348,18 +1348,18 @@ void subselect_uniquesubquery_engine::print(String *str)
|
|||||||
|
|
||||||
void subselect_indexsubquery_engine::print(String *str)
|
void subselect_indexsubquery_engine::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("<index_lookup>(");
|
str->append("<index_lookup>(", 15);
|
||||||
tab->ref.items[0]->print(str);
|
tab->ref.items[0]->print(str);
|
||||||
str->append(" in ");
|
str->append(" in ", 4);
|
||||||
str->append(tab->table->real_name);
|
str->append(tab->table->real_name);
|
||||||
KEY *key_info= tab->table->key_info+ tab->ref.key;
|
KEY *key_info= tab->table->key_info+ tab->ref.key;
|
||||||
str->append(" on ");
|
str->append(" on ", 4);
|
||||||
str->append(key_info->name);
|
str->append(key_info->name);
|
||||||
if (check_null)
|
if (check_null)
|
||||||
str->append(" chicking NULL");
|
str->append(" chicking NULL", 14);
|
||||||
if (cond)
|
if (cond)
|
||||||
{
|
{
|
||||||
str->append(" where ");
|
str->append(" where ", 7);
|
||||||
cond->print(str);
|
cond->print(str);
|
||||||
}
|
}
|
||||||
str->append(')');
|
str->append(')');
|
||||||
|
@ -1369,7 +1369,7 @@ longlong Item_sum_count_distinct::val_int()
|
|||||||
|
|
||||||
void Item_sum_count_distinct::print(String *str)
|
void Item_sum_count_distinct::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("count(distinct ");
|
str->append("count(distinct ", 15);
|
||||||
args[0]->print(str);
|
args[0]->print(str);
|
||||||
str->append(')');
|
str->append(')');
|
||||||
}
|
}
|
||||||
@ -1971,9 +1971,9 @@ String* Item_func_group_concat::val_str(String* str)
|
|||||||
|
|
||||||
void Item_func_group_concat::print(String *str)
|
void Item_func_group_concat::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("group concat(");
|
str->append("group_concat(", 13);
|
||||||
if (distinct)
|
if (distinct)
|
||||||
str->append(" distinct ");
|
str->append("distinct ", 9);
|
||||||
for (uint i= 0; i < arg_count; i++)
|
for (uint i= 0; i < arg_count; i++)
|
||||||
{
|
{
|
||||||
if (i)
|
if (i)
|
||||||
@ -1982,6 +1982,7 @@ void Item_func_group_concat::print(String *str)
|
|||||||
}
|
}
|
||||||
if (arg_count_order)
|
if (arg_count_order)
|
||||||
{
|
{
|
||||||
|
str->append(" order by ", 10);
|
||||||
for (uint i= 0 ; i < arg_count_order ; i++)
|
for (uint i= 0 ; i < arg_count_order ; i++)
|
||||||
{
|
{
|
||||||
if (i)
|
if (i)
|
||||||
@ -1989,7 +1990,7 @@ void Item_func_group_concat::print(String *str)
|
|||||||
(*order[i]->item)->print(str);
|
(*order[i]->item)->print(str);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
str->append(" seperator \'");
|
str->append(" seperator \'", 12);
|
||||||
str->append(*separator);
|
str->append(*separator);
|
||||||
str->append("\')");
|
str->append("\')", 2);
|
||||||
}
|
}
|
||||||
|
@ -433,7 +433,7 @@ String *make_datetime(String *str, TIME *l_time,
|
|||||||
length= int10_to_str(l_time->day, intbuff, 10) - intbuff;
|
length= int10_to_str(l_time->day, intbuff, 10) - intbuff;
|
||||||
str->append_with_prefill(intbuff, length, 1, '0');
|
str->append_with_prefill(intbuff, length, 1, '0');
|
||||||
if (l_time->day >= 10 && l_time->day <= 19)
|
if (l_time->day >= 10 && l_time->day <= 19)
|
||||||
str->append("th");
|
str->append("th", 2);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
switch (l_time->day %10) {
|
switch (l_time->day %10) {
|
||||||
@ -531,7 +531,7 @@ String *make_datetime(String *str, TIME *l_time,
|
|||||||
str->append_with_prefill(intbuff, length, 2, '0');
|
str->append_with_prefill(intbuff, length, 2, '0');
|
||||||
if (add_second_frac)
|
if (add_second_frac)
|
||||||
{
|
{
|
||||||
str->append(".", 1);
|
str->append('.');
|
||||||
length= int10_to_str(l_time->second_part, intbuff, 10) - intbuff;
|
length= int10_to_str(l_time->second_part, intbuff, 10) - intbuff;
|
||||||
str->append_with_prefill(intbuff, length, 6, '0');
|
str->append_with_prefill(intbuff, length, 6, '0');
|
||||||
}
|
}
|
||||||
@ -1660,15 +1660,16 @@ void Item_date_add_interval::print(String *str)
|
|||||||
args[0]->print(str);
|
args[0]->print(str);
|
||||||
str->append(date_sub_interval?" - interval ":" + interval ");
|
str->append(date_sub_interval?" - interval ":" + interval ");
|
||||||
args[1]->print(str);
|
args[1]->print(str);
|
||||||
|
str->append(' ');
|
||||||
str->append(interval_names[int_type]);
|
str->append(interval_names[int_type]);
|
||||||
str->append(')');
|
str->append(')');
|
||||||
}
|
}
|
||||||
|
|
||||||
void Item_extract::print(String *str)
|
void Item_extract::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("extract(");
|
str->append("extract(", 8);
|
||||||
str->append(interval_names[int_type]);
|
str->append(interval_names[int_type]);
|
||||||
str->append(' ');
|
str->append(" from ", 6);
|
||||||
args[0]->print(str);
|
args[0]->print(str);
|
||||||
str->append(')');
|
str->append(')');
|
||||||
}
|
}
|
||||||
@ -1780,29 +1781,31 @@ bool Item_extract::eq(const Item *item, bool binary_cmp) const
|
|||||||
|
|
||||||
void Item_typecast::print(String *str)
|
void Item_typecast::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("cast(");
|
str->append("cast(", 5);
|
||||||
args[0]->print(str);
|
args[0]->print(str);
|
||||||
str->append(" as ");
|
str->append(" as ", 4);
|
||||||
str->append(cast_type());
|
str->append(cast_type());
|
||||||
str->append(')');
|
str->append(')');
|
||||||
}
|
}
|
||||||
|
|
||||||
void Item_char_typecast::print(String *str)
|
void Item_char_typecast::print(String *str)
|
||||||
{
|
{
|
||||||
str->append("cast(");
|
str->append("cast(", 5);
|
||||||
args[0]->print(str);
|
args[0]->print(str);
|
||||||
str->append(" as char");
|
str->append(" as char", 8);
|
||||||
if (cast_length >= 0)
|
if (cast_length >= 0)
|
||||||
{
|
{
|
||||||
str->append('(');
|
str->append('(');
|
||||||
char buff[10];
|
char buffer[20];
|
||||||
snprintf(buff, 10, "%d", cast_length);
|
// latin1 is good enough for numbers
|
||||||
str->append(buff);
|
String st(buffer, sizeof(buffer), &my_charset_latin1);
|
||||||
|
st.set((ulonglong)cast_length, &my_charset_latin1);
|
||||||
|
str->append(st);
|
||||||
str->append(')');
|
str->append(')');
|
||||||
}
|
}
|
||||||
if (cast_cs)
|
if (cast_cs)
|
||||||
{
|
{
|
||||||
str->append(" charset ");
|
str->append(" charset ", 9);
|
||||||
str->append(cast_cs->name);
|
str->append(cast_cs->name);
|
||||||
}
|
}
|
||||||
str->append(')');
|
str->append(')');
|
||||||
@ -2095,14 +2098,14 @@ void Item_func_add_time::print(String *str)
|
|||||||
if (is_date)
|
if (is_date)
|
||||||
{
|
{
|
||||||
DBUG_ASSERT(sign > 0);
|
DBUG_ASSERT(sign > 0);
|
||||||
str->append("timestamp(");
|
str->append("timestamp(", 10);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (sign > 0)
|
if (sign > 0)
|
||||||
str->append("addtime(");
|
str->append("addtime(", 8);
|
||||||
else
|
else
|
||||||
str->append("subtime(");
|
str->append("subtime(", 8);
|
||||||
}
|
}
|
||||||
args[0]->print(str);
|
args[0]->print(str);
|
||||||
str->append(',');
|
str->append(',');
|
||||||
|
@ -285,7 +285,7 @@ public:
|
|||||||
Item_func_unix_timestamp() :Item_int_func() {}
|
Item_func_unix_timestamp() :Item_int_func() {}
|
||||||
Item_func_unix_timestamp(Item *a) :Item_int_func(a) {}
|
Item_func_unix_timestamp(Item *a) :Item_int_func(a) {}
|
||||||
longlong val_int();
|
longlong val_int();
|
||||||
const char *func_name() const { return "timestamp"; }
|
const char *func_name() const { return "unix_timestamp"; }
|
||||||
void fix_length_and_dec()
|
void fix_length_and_dec()
|
||||||
{
|
{
|
||||||
decimals=0;
|
decimals=0;
|
||||||
|
@ -29,7 +29,7 @@ public:
|
|||||||
:Item_real_func(list) {}
|
:Item_real_func(list) {}
|
||||||
double val() { return 0.0; }
|
double val() { return 0.0; }
|
||||||
void fix_length_and_dec() { decimals=0; max_length=6; }
|
void fix_length_and_dec() { decimals=0; max_length=6; }
|
||||||
void print(String *str) { str->append("0.0"); }
|
void print(String *str) { str->append("0.0", 3); }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -55,5 +55,5 @@ public:
|
|||||||
{
|
{
|
||||||
return new Item_sum_unique_users(thd, *this);
|
return new Item_sum_unique_users(thd, *this);
|
||||||
}
|
}
|
||||||
void print(String *str) { str->append("0.0"); }
|
void print(String *str) { str->append("0.0", 3); }
|
||||||
};
|
};
|
||||||
|
@ -227,7 +227,7 @@ void key_unpack(String *to,TABLE *table,uint idx)
|
|||||||
{
|
{
|
||||||
if (table->record[0][key_part->null_offset] & key_part->null_bit)
|
if (table->record[0][key_part->null_offset] & key_part->null_bit)
|
||||||
{
|
{
|
||||||
to->append("NULL");
|
to->append("NULL", 4);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -239,7 +239,7 @@ void key_unpack(String *to,TABLE *table,uint idx)
|
|||||||
to->append(tmp);
|
to->append(tmp);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
to->append("???");
|
to->append("???", 3);
|
||||||
}
|
}
|
||||||
DBUG_VOID_RETURN;
|
DBUG_VOID_RETURN;
|
||||||
}
|
}
|
||||||
|
@ -1477,9 +1477,9 @@ void st_select_lex_unit::print(String *str)
|
|||||||
{
|
{
|
||||||
if (sl != first_select())
|
if (sl != first_select())
|
||||||
{
|
{
|
||||||
str->append(" union ");
|
str->append(" union ", 7);
|
||||||
if (union_option & UNION_ALL)
|
if (union_option & UNION_ALL)
|
||||||
str->append("all ");
|
str->append("all ", 4);
|
||||||
}
|
}
|
||||||
if (sl->braces)
|
if (sl->braces)
|
||||||
str->append('(');
|
str->append('(');
|
||||||
@ -1491,7 +1491,7 @@ void st_select_lex_unit::print(String *str)
|
|||||||
{
|
{
|
||||||
if (fake_select_lex->order_list.elements)
|
if (fake_select_lex->order_list.elements)
|
||||||
{
|
{
|
||||||
str->append(" order by ");
|
str->append(" order by ", 10);
|
||||||
fake_select_lex->print_order(str,
|
fake_select_lex->print_order(str,
|
||||||
(ORDER *) fake_select_lex->
|
(ORDER *) fake_select_lex->
|
||||||
order_list.first);
|
order_list.first);
|
||||||
@ -1507,7 +1507,7 @@ void st_select_lex::print_order(String *str, ORDER *order)
|
|||||||
{
|
{
|
||||||
(*order->item)->print(str);
|
(*order->item)->print(str);
|
||||||
if (!order->asc)
|
if (!order->asc)
|
||||||
str->append(" desc");
|
str->append(" desc", 5);
|
||||||
if (order->next)
|
if (order->next)
|
||||||
str->append(',');
|
str->append(',');
|
||||||
}
|
}
|
||||||
@ -1522,15 +1522,17 @@ void st_select_lex::print_limit(THD *thd, String *str)
|
|||||||
select_limit != HA_POS_ERROR ||
|
select_limit != HA_POS_ERROR ||
|
||||||
offset_limit != 0L)
|
offset_limit != 0L)
|
||||||
{
|
{
|
||||||
str->append(" limit ");
|
str->append(" limit ", 7);
|
||||||
char buff[21];
|
char buff[20];
|
||||||
snprintf(buff, 21, "%ld", select_limit);
|
// latin1 is good enough for numbers
|
||||||
str->append(buff);
|
String st(buff, sizeof(buff), &my_charset_latin1);
|
||||||
|
st.set((ulonglong)select_limit, &my_charset_latin1);
|
||||||
|
str->append(st);
|
||||||
if (offset_limit)
|
if (offset_limit)
|
||||||
{
|
{
|
||||||
str->append(',');
|
str->append(',');
|
||||||
snprintf(buff, 21, "%ld", offset_limit);
|
st.set((ulonglong)select_limit, &my_charset_latin1);
|
||||||
str->append(buff);
|
str->append(st);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4741,7 +4741,7 @@ Item * all_any_subquery_creator(Item *left_expr,
|
|||||||
return new Item_func_not(new Item_in_subselect(left_expr, select_lex));
|
return new Item_func_not(new Item_in_subselect(left_expr, select_lex));
|
||||||
|
|
||||||
Item_allany_subselect *it=
|
Item_allany_subselect *it=
|
||||||
new Item_allany_subselect(left_expr, (*cmp)(all), select_lex);
|
new Item_allany_subselect(left_expr, (*cmp)(all), select_lex, all);
|
||||||
if (all)
|
if (all)
|
||||||
return it->upper_not= new Item_func_not_all(it); /* ALL */
|
return it->upper_not= new Item_func_not_all(it); /* ALL */
|
||||||
|
|
||||||
|
@ -625,7 +625,7 @@ Increase max_allowed_packet on master";
|
|||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
packet->length(0);
|
packet->length(0);
|
||||||
packet->append("\0",1);
|
packet->append('\0');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -8948,28 +8948,28 @@ void st_select_lex::print(THD *thd, String *str)
|
|||||||
if (!thd)
|
if (!thd)
|
||||||
thd= current_thd;
|
thd= current_thd;
|
||||||
|
|
||||||
str->append("select ");
|
str->append("select ", 7);
|
||||||
|
|
||||||
//options
|
//options
|
||||||
if (options & SELECT_STRAIGHT_JOIN)
|
if (options & SELECT_STRAIGHT_JOIN)
|
||||||
str->append("straight_join ");
|
str->append("straight_join ", 14);
|
||||||
if ((thd->lex.lock_option & TL_READ_HIGH_PRIORITY) &&
|
if ((thd->lex.lock_option & TL_READ_HIGH_PRIORITY) &&
|
||||||
(this == &thd->lex.select_lex))
|
(this == &thd->lex.select_lex))
|
||||||
str->append("high_priority ");
|
str->append("high_priority ", 14);
|
||||||
if (options & SELECT_DISTINCT)
|
if (options & SELECT_DISTINCT)
|
||||||
str->append("distinct ");
|
str->append("distinct ", 9);
|
||||||
if (options & SELECT_SMALL_RESULT)
|
if (options & SELECT_SMALL_RESULT)
|
||||||
str->append("small_result ");
|
str->append("small_result ", 13);
|
||||||
if (options & SELECT_BIG_RESULT)
|
if (options & SELECT_BIG_RESULT)
|
||||||
str->append("big_result ");
|
str->append("big_result ", 11);
|
||||||
if (options & OPTION_BUFFER_RESULT)
|
if (options & OPTION_BUFFER_RESULT)
|
||||||
str->append("buffer_result ");
|
str->append("buffer_result ", 14);
|
||||||
if (options & OPTION_FOUND_ROWS)
|
if (options & OPTION_FOUND_ROWS)
|
||||||
str->append("calc_found_rows ");
|
str->append("calc_found_rows ", 16);
|
||||||
if (!thd->lex.safe_to_cache_query)
|
if (!thd->lex.safe_to_cache_query)
|
||||||
str->append("no_cache ");
|
str->append("no_cache ", 9);
|
||||||
if (options & OPTION_TO_QUERY_CACHE)
|
if (options & OPTION_TO_QUERY_CACHE)
|
||||||
str->append("cache ");
|
str->append("cache ", 6);
|
||||||
|
|
||||||
//Item List
|
//Item List
|
||||||
bool first= 1;
|
bool first= 1;
|
||||||
@ -8990,7 +8990,7 @@ void st_select_lex::print(THD *thd, String *str)
|
|||||||
*/
|
*/
|
||||||
if (table_list.elements)
|
if (table_list.elements)
|
||||||
{
|
{
|
||||||
str->append(" from ");
|
str->append(" from ", 6);
|
||||||
Item *next_on= 0;
|
Item *next_on= 0;
|
||||||
for (TABLE_LIST *table= (TABLE_LIST *) table_list.first;
|
for (TABLE_LIST *table= (TABLE_LIST *) table_list.first;
|
||||||
table;
|
table;
|
||||||
@ -9021,7 +9021,7 @@ void st_select_lex::print(THD *thd, String *str)
|
|||||||
|
|
||||||
if (next_on)
|
if (next_on)
|
||||||
{
|
{
|
||||||
str->append(" on(");
|
str->append(" on(", 4);
|
||||||
next_on->print(str);
|
next_on->print(str);
|
||||||
str->append(')');
|
str->append(')');
|
||||||
next_on= 0;
|
next_on= 0;
|
||||||
@ -9032,17 +9032,17 @@ void st_select_lex::print(THD *thd, String *str)
|
|||||||
{
|
{
|
||||||
if (table->outer_join & JOIN_TYPE_RIGHT)
|
if (table->outer_join & JOIN_TYPE_RIGHT)
|
||||||
{
|
{
|
||||||
str->append(" right join ");
|
str->append(" right join ", 12);
|
||||||
if (!(table->outer_join & JOIN_TYPE_LEFT) &&
|
if (!(table->outer_join & JOIN_TYPE_LEFT) &&
|
||||||
table->on_expr)
|
table->on_expr)
|
||||||
next_on= table->on_expr;
|
next_on= table->on_expr;
|
||||||
}
|
}
|
||||||
else if (next->straight)
|
else if (next->straight)
|
||||||
str->append(" straight_join ");
|
str->append(" straight_join ", 15);
|
||||||
else if (next->outer_join & JOIN_TYPE_LEFT)
|
else if (next->outer_join & JOIN_TYPE_LEFT)
|
||||||
str->append(" left join ");
|
str->append(" left join ", 11);
|
||||||
else
|
else
|
||||||
str->append(" join ");
|
str->append(" join ", 6);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -9053,22 +9053,22 @@ void st_select_lex::print(THD *thd, String *str)
|
|||||||
where= join->conds;
|
where= join->conds;
|
||||||
if (where)
|
if (where)
|
||||||
{
|
{
|
||||||
str->append(" where ");
|
str->append(" where ", 7);
|
||||||
where->print(str);
|
where->print(str);
|
||||||
}
|
}
|
||||||
|
|
||||||
//group by & olap
|
//group by & olap
|
||||||
if (group_list.elements)
|
if (group_list.elements)
|
||||||
{
|
{
|
||||||
str->append(" group by ");
|
str->append(" group by ", 10);
|
||||||
print_order(str, (ORDER *) group_list.first);
|
print_order(str, (ORDER *) group_list.first);
|
||||||
switch (olap)
|
switch (olap)
|
||||||
{
|
{
|
||||||
case CUBE_TYPE:
|
case CUBE_TYPE:
|
||||||
str->append(" with cube");
|
str->append(" with cube", 10);
|
||||||
break;
|
break;
|
||||||
case ROLLUP_TYPE:
|
case ROLLUP_TYPE:
|
||||||
str->append(" with rollup");
|
str->append(" with rollup", 12);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
; //satisfy compiler
|
; //satisfy compiler
|
||||||
@ -9082,13 +9082,13 @@ void st_select_lex::print(THD *thd, String *str)
|
|||||||
|
|
||||||
if (having)
|
if (having)
|
||||||
{
|
{
|
||||||
str->append(" having ");
|
str->append(" having ", 8);
|
||||||
having->print(str);
|
having->print(str);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (order_list.elements)
|
if (order_list.elements)
|
||||||
{
|
{
|
||||||
str->append(" order by ");
|
str->append(" order by ", 10);
|
||||||
print_order(str, (ORDER *) order_list.first);
|
print_order(str, (ORDER *) order_list.first);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1111,12 +1111,12 @@ store_create_info(THD *thd, TABLE *table, String *packet)
|
|||||||
if (field->has_charset())
|
if (field->has_charset())
|
||||||
{
|
{
|
||||||
if (field->charset() == &my_charset_bin)
|
if (field->charset() == &my_charset_bin)
|
||||||
packet->append(" binary");
|
packet->append(" binary", 7);
|
||||||
else if (!limited_mysql_mode && !foreign_db_mode)
|
else if (!limited_mysql_mode && !foreign_db_mode)
|
||||||
{
|
{
|
||||||
if (field->charset() != table->table_charset)
|
if (field->charset() != table->table_charset)
|
||||||
{
|
{
|
||||||
packet->append(" character set ");
|
packet->append(" character set ", 15);
|
||||||
packet->append(field->charset()->csname);
|
packet->append(field->charset()->csname);
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
@ -1253,32 +1253,32 @@ store_create_info(THD *thd, TABLE *table, String *packet)
|
|||||||
!(thd->variables.sql_mode & MODE_MYSQL323) &&
|
!(thd->variables.sql_mode & MODE_MYSQL323) &&
|
||||||
!(thd->variables.sql_mode & MODE_MYSQL40))
|
!(thd->variables.sql_mode & MODE_MYSQL40))
|
||||||
{
|
{
|
||||||
packet->append(" CHARSET=");
|
packet->append(" CHARSET=", 9);
|
||||||
packet->append(table->table_charset->csname);
|
packet->append(table->table_charset->csname);
|
||||||
if (!(table->table_charset->state & MY_CS_PRIMARY))
|
if (!(table->table_charset->state & MY_CS_PRIMARY))
|
||||||
{
|
{
|
||||||
packet->append(" COLLATE=");
|
packet->append(" COLLATE=", 9);
|
||||||
packet->append(table->table_charset->name);
|
packet->append(table->table_charset->name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (table->min_rows)
|
if (table->min_rows)
|
||||||
{
|
{
|
||||||
packet->append(" MIN_ROWS=");
|
packet->append(" MIN_ROWS=", 10);
|
||||||
end= longlong10_to_str(table->min_rows, buff, 10);
|
end= longlong10_to_str(table->min_rows, buff, 10);
|
||||||
packet->append(buff, (uint) (end- buff));
|
packet->append(buff, (uint) (end- buff));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (table->max_rows)
|
if (table->max_rows)
|
||||||
{
|
{
|
||||||
packet->append(" MAX_ROWS=");
|
packet->append(" MAX_ROWS=", 10);
|
||||||
end= longlong10_to_str(table->max_rows, buff, 10);
|
end= longlong10_to_str(table->max_rows, buff, 10);
|
||||||
packet->append(buff, (uint) (end - buff));
|
packet->append(buff, (uint) (end - buff));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (table->avg_row_length)
|
if (table->avg_row_length)
|
||||||
{
|
{
|
||||||
packet->append(" AVG_ROW_LENGTH=");
|
packet->append(" AVG_ROW_LENGTH=", 16);
|
||||||
end= longlong10_to_str(table->avg_row_length, buff,10);
|
end= longlong10_to_str(table->avg_row_length, buff,10);
|
||||||
packet->append(buff, (uint) (end - buff));
|
packet->append(buff, (uint) (end - buff));
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user