Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
090cecd5
Commit
090cecd5
authored
Aug 30, 2023
by
Lena Startseva
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
MDEV-31933: Make working view-protocol + ps-protocol (running two protocols together)
Fix for v. 10.5
parent
d046b13e
Changes
11
Show whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
139 additions
and
1 deletion
+139
-1
mysql-test/main/distinct_notembedded.test
mysql-test/main/distinct_notembedded.test
+4
-0
mysql-test/main/group_min_max_notembedded.test
mysql-test/main/group_min_max_notembedded.test
+3
-0
mysql-test/main/having.test
mysql-test/main/having.test
+9
-0
mysql-test/main/opt_trace.test
mysql-test/main/opt_trace.test
+92
-0
mysql-test/main/opt_trace_index_merge.test
mysql-test/main/opt_trace_index_merge.test
+2
-0
mysql-test/main/opt_trace_index_merge_innodb.test
mysql-test/main/opt_trace_index_merge_innodb.test
+2
-0
mysql-test/main/opt_trace_ucs2.test
mysql-test/main/opt_trace_ucs2.test
+3
-0
mysql-test/main/range_notembedded.test
mysql-test/main/range_notembedded.test
+3
-0
mysql-test/main/selectivity_notembedded.test
mysql-test/main/selectivity_notembedded.test
+13
-1
mysql-test/main/subselect.test
mysql-test/main/subselect.test
+6
-0
mysql-test/main/temp_table_symlink.test
mysql-test/main/temp_table_symlink.test
+2
-0
No files found.
mysql-test/main/distinct_notembedded.test
View file @
090cecd5
...
@@ -6,6 +6,8 @@
...
@@ -6,6 +6,8 @@
--
echo
# MDEV-30660 COUNT DISTINCT seems unnecessarily slow when run on a PK
--
echo
# MDEV-30660 COUNT DISTINCT seems unnecessarily slow when run on a PK
--
echo
#
--
echo
#
#Enable after fix MDEV-32034
--
disable_view_protocol
set
@
save_optimizer_trace
=
@@
optimizer_trace
;
set
@
save_optimizer_trace
=
@@
optimizer_trace
;
SET
optimizer_trace
=
'enabled=on'
;
SET
optimizer_trace
=
'enabled=on'
;
let
$trace
=
let
$trace
=
...
@@ -104,6 +106,8 @@ eval $trace;
...
@@ -104,6 +106,8 @@ eval $trace;
DROP
TABLE
t1
,
t2
,
t3
;
DROP
TABLE
t1
,
t2
,
t3
;
DROP
VIEW
v1
;
DROP
VIEW
v1
;
SET
optimizer_trace
=
@
save_optimizer_trace
;
SET
optimizer_trace
=
@
save_optimizer_trace
;
--
enable_view_protocol
--
echo
#
--
echo
#
--
echo
# end of 10.5 tests
--
echo
# end of 10.5 tests
--
echo
#
--
echo
#
mysql-test/main/group_min_max_notembedded.test
View file @
090cecd5
...
@@ -23,10 +23,13 @@ SET
...
@@ -23,10 +23,13 @@ SET
SELECT
DISTINCT
*
FROM
t1
WHERE
a
IN
(
1
,
2
);
SELECT
DISTINCT
*
FROM
t1
WHERE
a
IN
(
1
,
2
);
#Enable after fix MDEV-32034
--
disable_view_protocol
select
select
CAST
(
json_value
(
json_extract
(
trace
,
'$**.chosen_access_method.cost'
),
'$[0]'
)
CAST
(
json_value
(
json_extract
(
trace
,
'$**.chosen_access_method.cost'
),
'$[0]'
)
as
DOUBLE
)
<
1.0e100
as
ACCESS_METHOD_COST_IS_FINITE
as
DOUBLE
)
<
1.0e100
as
ACCESS_METHOD_COST_IS_FINITE
from
information_schema
.
optimizer_trace
;
from
information_schema
.
optimizer_trace
;
--
enable_view_protocol
set
optimizer_use_condition_selectivity
=
@
tmp
,
optimizer_trace
=@
tmp2
;
set
optimizer_use_condition_selectivity
=
@
tmp
,
optimizer_trace
=@
tmp2
;
drop
table
t1
;
drop
table
t1
;
...
...
mysql-test/main/having.test
View file @
090cecd5
...
@@ -258,6 +258,8 @@ where t1.col2 in
...
@@ -258,6 +258,8 @@ where t1.col2 in
# the having column is resolved in the FROM clause of the outer query -
# the having column is resolved in the FROM clause of the outer query -
# works in ANSI
# works in ANSI
#Enable after fix MDEV-31937
--
disable_ps2_protocol
select
t1
.
col1
from
t1
select
t1
.
col1
from
t1
where
t1
.
col2
in
where
t1
.
col2
in
(
select
t2
.
col2
from
t2
(
select
t2
.
col2
from
t2
...
@@ -284,6 +286,7 @@ where t1.col2 in
...
@@ -284,6 +286,7 @@ where t1.col2 in
group
by
t2
.
col1
,
t2
.
col2
having
col_t1
<=
10
)
group
by
t2
.
col1
,
t2
.
col2
having
col_t1
<=
10
)
group
by
col_t1
group
by
col_t1
having
col_t1
<=
20
;
having
col_t1
<=
20
;
--
enable_ps2_protocol
#
#
# nested HAVING clauses
# nested HAVING clauses
...
@@ -412,11 +415,14 @@ INSERT INTO PROJ VALUES ('P4','SDP','Design',20000,'Deale');
...
@@ -412,11 +415,14 @@ INSERT INTO PROJ VALUES ('P4','SDP','Design',20000,'Deale');
INSERT
INTO
PROJ
VALUES
(
'P5'
,
'IRM'
,
'Test'
,
10000
,
'Vienna'
);
INSERT
INTO
PROJ
VALUES
(
'P5'
,
'IRM'
,
'Test'
,
10000
,
'Vienna'
);
INSERT
INTO
PROJ
VALUES
(
'P6'
,
'PAYR'
,
'Design'
,
50000
,
'Deale'
);
INSERT
INTO
PROJ
VALUES
(
'P6'
,
'PAYR'
,
'Design'
,
50000
,
'Deale'
);
#Enable after fix MDEV-31937
--
disable_ps2_protocol
SELECT
EMPNUM
,
GRADE
*
1000
SELECT
EMPNUM
,
GRADE
*
1000
FROM
HU
.
STAFF
WHERE
GRADE
*
1000
>
FROM
HU
.
STAFF
WHERE
GRADE
*
1000
>
ANY
(
SELECT
SUM
(
BUDGET
)
FROM
HU
.
PROJ
ANY
(
SELECT
SUM
(
BUDGET
)
FROM
HU
.
PROJ
GROUP
BY
CITY
,
PTYPE
GROUP
BY
CITY
,
PTYPE
HAVING
HU
.
PROJ
.
CITY
=
HU
.
STAFF
.
CITY
);
HAVING
HU
.
PROJ
.
CITY
=
HU
.
STAFF
.
CITY
);
--
enable_ps2_protocol
DROP
SCHEMA
HU
;
DROP
SCHEMA
HU
;
USE
test
;
USE
test
;
...
@@ -956,6 +962,8 @@ DROP TABLE t;
...
@@ -956,6 +962,8 @@ DROP TABLE t;
--
echo
# MDEV-29731 Crash when HAVING in a correlated subquery references
--
echo
# MDEV-29731 Crash when HAVING in a correlated subquery references
--
echo
# columns in the outer query
--
echo
# columns in the outer query
--
echo
#
--
echo
#
#Enable after fix MDEV-29731
--
disable_view_protocol
CREATE
TABLE
t
(
a
INT
,
b
INT
);
CREATE
TABLE
t
(
a
INT
,
b
INT
);
SELECT
1
FROM
t
SELECT
1
FROM
t
WHERE
b
=
(
SELECT
1
FROM
t
GROUP
BY
a
HAVING
b
=
a
+
1
);
WHERE
b
=
(
SELECT
1
FROM
t
GROUP
BY
a
HAVING
b
=
a
+
1
);
...
@@ -998,6 +1006,7 @@ UPDATE t SET a = ''
...
@@ -998,6 +1006,7 @@ UPDATE t SET a = ''
WHERE
(
0
,
a
)
IN
((
0
,
-
1
),(
+
1
,
0
))
WHERE
(
0
,
a
)
IN
((
0
,
-
1
),(
+
1
,
0
))
ORDER
BY
1
+
AVG
(
a
)
OVER
(
ORDER
BY
a
))
ORDER
BY
a
;
ORDER
BY
1
+
AVG
(
a
)
OVER
(
ORDER
BY
a
))
ORDER
BY
a
;
DROP
TABLE
t
;
DROP
TABLE
t
;
--
enable_view_protocol
--
echo
#
--
echo
#
--
echo
# End of 10.4 tests
--
echo
# End of 10.4 tests
...
...
mysql-test/main/opt_trace.test
View file @
090cecd5
...
@@ -77,7 +77,9 @@ analyze table t1;
...
@@ -77,7 +77,9 @@ analyze table t1;
analyze
table
t2
;
analyze
table
t2
;
explain
select
*
from
t1
,
t2
where
t1
.
a
=
t2
.
b
+
2
and
t2
.
a
=
t1
.
b
;
explain
select
*
from
t1
,
t2
where
t1
.
a
=
t2
.
b
+
2
and
t2
.
a
=
t1
.
b
;
--
disable_view_protocol
select
*
from
information_schema
.
OPTIMIZER_TRACE
;
select
*
from
information_schema
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t1
,
t2
,
t0
;
drop
table
t1
,
t2
,
t0
;
--
echo
#
--
echo
#
...
@@ -104,7 +106,9 @@ INSERT INTO t1(a) SELECT a FROM t1;
...
@@ -104,7 +106,9 @@ INSERT INTO t1(a) SELECT a FROM t1;
analyze
table
t1
;
analyze
table
t1
;
EXPLAIN
SELECT
DISTINCT
a
FROM
t1
;
EXPLAIN
SELECT
DISTINCT
a
FROM
t1
;
--
disable_view_protocol
select
*
from
information_schema
.
OPTIMIZER_TRACE
;
select
*
from
information_schema
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t1
;
drop
table
t1
;
--
echo
#
--
echo
#
...
@@ -114,7 +118,9 @@ CREATE TABLE t1 (a INT, b INT, c int, d int, KEY(a,b,c,d));
...
@@ -114,7 +118,9 @@ CREATE TABLE t1 (a INT, b INT, c int, d int, KEY(a,b,c,d));
INSERT
INTO
t1
VALUES
(
1
,
1
,
1
,
1
),
(
2
,
2
,
2
,
2
),
(
3
,
3
,
3
,
3
),
(
4
,
4
,
4
,
4
),
(
1
,
0
,
1
,
1
),
(
3
,
2
,
3
,
3
),
(
4
,
5
,
4
,
4
);
INSERT
INTO
t1
VALUES
(
1
,
1
,
1
,
1
),
(
2
,
2
,
2
,
2
),
(
3
,
3
,
3
,
3
),
(
4
,
4
,
4
,
4
),
(
1
,
0
,
1
,
1
),
(
3
,
2
,
3
,
3
),
(
4
,
5
,
4
,
4
);
ANALYZE
TABLE
t1
;
ANALYZE
TABLE
t1
;
EXPLAIN
SELECT
MIN
(
d
)
FROM
t1
where
b
=
2
and
c
=
3
group
by
a
;
EXPLAIN
SELECT
MIN
(
d
)
FROM
t1
where
b
=
2
and
c
=
3
group
by
a
;
--
disable_view_protocol
select
*
from
information_schema
.
OPTIMIZER_TRACE
;
select
*
from
information_schema
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
DROP
TABLE
t1
;
DROP
TABLE
t1
;
CREATE
TABLE
t1
(
id
INT
NOT
NULL
,
a
DATE
,
KEY
(
id
,
a
));
CREATE
TABLE
t1
(
id
INT
NOT
NULL
,
a
DATE
,
KEY
(
id
,
a
));
...
@@ -128,9 +134,13 @@ INSERT INTO t1 values (1,'2001-01-01'),(1,'2001-01-02'),
...
@@ -128,9 +134,13 @@ INSERT INTO t1 values (1,'2001-01-01'),(1,'2001-01-02'),
(
4
,
'2001-01-03'
),(
4
,
'2001-01-04'
);
(
4
,
'2001-01-03'
),(
4
,
'2001-01-04'
);
set
optimizer_trace
=
'enabled=on'
;
set
optimizer_trace
=
'enabled=on'
;
EXPLAIN
SELECT
id
,
MIN
(
a
),
MAX
(
a
)
FROM
t1
WHERE
a
>=
20010104
e0
GROUP
BY
id
;
EXPLAIN
SELECT
id
,
MIN
(
a
),
MAX
(
a
)
FROM
t1
WHERE
a
>=
20010104
e0
GROUP
BY
id
;
--
disable_view_protocol
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
EXPLAIN
SELECT
*
FROM
t1
WHERE
a
=
20010104
e0
GROUP
BY
id
;
EXPLAIN
SELECT
*
FROM
t1
WHERE
a
=
20010104
e0
GROUP
BY
id
;
--
disable_view_protocol
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t1
;
drop
table
t1
;
--
echo
#
--
echo
#
...
@@ -159,7 +169,9 @@ update t1 set b=2 where pk between 0 and 20;
...
@@ -159,7 +169,9 @@ update t1 set b=2 where pk between 0 and 20;
analyze
table
t1
;
analyze
table
t1
;
set
optimizer_trace
=
'enabled=on'
;
set
optimizer_trace
=
'enabled=on'
;
explain
select
*
from
t1
where
a
=
1
and
b
=
2
order
by
c
limit
1
;
explain
select
*
from
t1
where
a
=
1
and
b
=
2
order
by
c
limit
1
;
--
disable_view_protocol
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t1
,
ten
,
one_k
;
drop
table
t1
,
ten
,
one_k
;
--
echo
#
--
echo
#
...
@@ -185,15 +197,21 @@ analyze table t3;
...
@@ -185,15 +197,21 @@ analyze table t3;
--
echo
# table t2 should be eliminated
--
echo
# table t2 should be eliminated
explain
explain
select
t1
.
a
from
t1
left
join
t2
on
t1
.
a
=
t2
.
a
;
select
t1
.
a
from
t1
left
join
t2
on
t1
.
a
=
t2
.
a
;
--
disable_view_protocol
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
--
echo
# no tables should be eliminated
--
echo
# no tables should be eliminated
explain
select
*
from
t1
left
join
t2
on
t2
.
a
=
t1
.
a
;
explain
select
*
from
t1
left
join
t2
on
t2
.
a
=
t1
.
a
;
--
disable_view_protocol
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
--
echo
# multiple tables are eliminated
--
echo
# multiple tables are eliminated
explain
select
t1
.
a
from
t1
left
join
(
t2
join
t3
on
t2
.
b
=
t3
.
b
)
on
t2
.
a
=
t1
.
a
and
t3
.
a
=
t1
.
a
;
explain
select
t1
.
a
from
t1
left
join
(
t2
join
t3
on
t2
.
b
=
t3
.
b
)
on
t2
.
a
=
t1
.
a
and
t3
.
a
=
t1
.
a
;
--
disable_view_protocol
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t0
,
t1
,
t2
,
t3
;
drop
table
t0
,
t1
,
t2
,
t3
;
--
echo
#
--
echo
#
...
@@ -218,7 +236,9 @@ analyze table t1,t10;
...
@@ -218,7 +236,9 @@ analyze table t1,t10;
set
optimizer_trace
=
'enabled=on'
;
set
optimizer_trace
=
'enabled=on'
;
explain
extended
select
*
from
t1
where
a
in
(
select
pk
from
t10
);
explain
extended
select
*
from
t1
where
a
in
(
select
pk
from
t10
);
--
disable_view_protocol
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t0
,
t1
,
t11
,
t10
,
t12
,
t2
;
drop
table
t0
,
t1
,
t11
,
t10
,
t12
,
t2
;
--
echo
#
--
echo
#
...
@@ -244,7 +264,9 @@ set @@optimizer_use_condition_selectivity=4;
...
@@ -244,7 +264,9 @@ set @@optimizer_use_condition_selectivity=4;
set
@@
use_stat_tables
=
PREFERABLY
;
set
@@
use_stat_tables
=
PREFERABLY
;
set
optimizer_trace
=
'enabled=on'
;
set
optimizer_trace
=
'enabled=on'
;
explain
select
*
from
t1
where
pk
=
2
and
a
=
5
and
b
=
1
;
explain
select
*
from
t1
where
pk
=
2
and
a
=
5
and
b
=
1
;
--
disable_view_protocol
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
set
@@
optimizer_use_condition_selectivity
=@
save_optimizer_use_condition_selectivity
;
set
@@
optimizer_use_condition_selectivity
=@
save_optimizer_use_condition_selectivity
;
set
@@
use_stat_tables
=
@
save_use_stat_tables
;
set
@@
use_stat_tables
=
@
save_use_stat_tables
;
drop
table
t0
,
t1
;
drop
table
t0
,
t1
;
...
@@ -321,7 +343,9 @@ alter table t0 add key(a);
...
@@ -321,7 +343,9 @@ alter table t0 add key(a);
set
optimizer_trace
=
1
;
set
optimizer_trace
=
1
;
explain
delete
from
t0
where
t0
.
a
<
3
;
explain
delete
from
t0
where
t0
.
a
<
3
;
--
disable_view_protocol
select
*
from
information_schema
.
optimizer_trace
;
select
*
from
information_schema
.
optimizer_trace
;
--
enable_view_protocol
drop
table
ten
,
t0
;
drop
table
ten
,
t0
;
set
optimizer_trace
=
'enabled=off'
;
set
optimizer_trace
=
'enabled=off'
;
...
@@ -338,7 +362,9 @@ alter table t0 add key(a);
...
@@ -338,7 +362,9 @@ alter table t0 add key(a);
create
table
t1
like
t0
;
create
table
t1
like
t0
;
insert
into
t1
select
*
from
t0
;
insert
into
t1
select
*
from
t0
;
explain
delete
t0
,
t1
from
t0
,
t1
where
t0
.
a
=
t1
.
a
and
t1
.
a
<
3
;
explain
delete
t0
,
t1
from
t0
,
t1
where
t0
.
a
=
t1
.
a
and
t1
.
a
<
3
;
--
disable_view_protocol
select
*
from
information_schema
.
optimizer_trace
;
select
*
from
information_schema
.
optimizer_trace
;
--
enable_view_protocol
drop
table
ten
,
t0
,
t1
;
drop
table
ten
,
t0
,
t1
;
set
optimizer_trace
=
'enabled=off'
;
set
optimizer_trace
=
'enabled=off'
;
...
@@ -350,7 +376,9 @@ set optimizer_trace=1;
...
@@ -350,7 +376,9 @@ set optimizer_trace=1;
create
table
t1
(
a
int
);
create
table
t1
(
a
int
);
insert
into
t1
values
(
1
),(
2
),(
3
);
insert
into
t1
values
(
1
),(
2
),(
3
);
explain
select
*
from
(
select
rand
()
from
t1
)
q
;
explain
select
*
from
(
select
rand
()
from
t1
)
q
;
--
disable_view_protocol
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t1
;
drop
table
t1
;
set
optimizer_trace
=
'enabled=off'
;
set
optimizer_trace
=
'enabled=off'
;
...
@@ -365,6 +393,7 @@ create table t2(a int);
...
@@ -365,6 +393,7 @@ create table t2(a int);
insert
into
t2
values
(
1
),(
2
),(
3
),(
1
),(
2
),(
3
),(
1
),(
2
),(
3
);
insert
into
t2
values
(
1
),(
2
),(
3
),(
1
),(
2
),(
3
),(
1
),(
2
),(
3
);
set
@
save_optimizer_switch
=
@@
optimizer_switch
;
set
@
save_optimizer_switch
=
@@
optimizer_switch
;
explain
select
*
from
t1
where
a
in
(
select
t_inner_1
.
a
from
t1
t_inner_1
,
t1
t_inner_2
);
explain
select
*
from
t1
where
a
in
(
select
t_inner_1
.
a
from
t1
t_inner_1
,
t1
t_inner_2
);
--
disable_view_protocol
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
echo
# with Firstmatch, mostly for tracing fix_semijoin_strategies_for_picked_join_order
--
echo
# with Firstmatch, mostly for tracing fix_semijoin_strategies_for_picked_join_order
...
@@ -377,6 +406,7 @@ set optimizer_switch='materialization=on';
...
@@ -377,6 +406,7 @@ set optimizer_switch='materialization=on';
explain
select
*
from
t1
t_outer_1
,
t2
t_outer_2
where
t_outer_1
.
a
in
(
select
t_inner_1
.
a
from
t2
t_inner_2
,
t1
t_inner_1
)
and
explain
select
*
from
t1
t_outer_1
,
t2
t_outer_2
where
t_outer_1
.
a
in
(
select
t_inner_1
.
a
from
t2
t_inner_2
,
t1
t_inner_1
)
and
t_outer_2
.
a
in
(
select
t_inner_3
.
a
from
t2
t_inner_3
,
t1
t_inner_4
);
t_outer_2
.
a
in
(
select
t_inner_3
.
a
from
t2
t_inner_3
,
t1
t_inner_4
);
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
*
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
set
@@
optimizer_switch
=
@
save_optimizer_switch
;
set
@@
optimizer_switch
=
@
save_optimizer_switch
;
drop
table
t1
,
t2
;
drop
table
t1
,
t2
;
...
@@ -405,11 +435,14 @@ create table t1 ( a int, b int, key a_b(a,b));
...
@@ -405,11 +435,14 @@ create table t1 ( a int, b int, key a_b(a,b));
insert
into
t1
select
a
,
a
from
one_k
;
insert
into
t1
select
a
,
a
from
one_k
;
set
optimizer_trace
=
'enabled=on'
;
set
optimizer_trace
=
'enabled=on'
;
#Enable after fix MDEV-32034
--
disable_view_protocol
explain
select
*
from
t1
force
index
(
a_b
)
where
a
=
2
and
b
=
4
;
explain
select
*
from
t1
force
index
(
a_b
)
where
a
=
2
and
b
=
4
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
explain
select
*
from
t1
where
a
>=
900
and
b
between
10
and
20
;
explain
select
*
from
t1
where
a
>=
900
and
b
between
10
and
20
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t0
,
t1
;
drop
table
t0
,
t1
;
...
@@ -418,7 +451,10 @@ create table t1 (start_date date, end_date date, filler char(100), key(start_dat
...
@@ -418,7 +451,10 @@ create table t1 (start_date date, end_date date, filler char(100), key(start_dat
insert
into
t1
select
date_add
(
now
(),
interval
a
day
),
date_add
(
now
(),
interval
(
a
+
7
)
day
),
'data'
from
one_k
;
insert
into
t1
select
date_add
(
now
(),
interval
a
day
),
date_add
(
now
(),
interval
(
a
+
7
)
day
),
'data'
from
one_k
;
--
enable_warnings
--
enable_warnings
explain
select
*
from
t1
force
index
(
start_date
)
where
start_date
>=
'2019-02-10'
and
end_date
<
'2019-04-01'
;
explain
select
*
from
t1
force
index
(
start_date
)
where
start_date
>=
'2019-02-10'
and
end_date
<
'2019-04-01'
;
#Enable after fix MDEV-32034
--
disable_view_protocol
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t1
,
one_k
;
drop
table
t1
,
one_k
;
create
table
ten
(
a
int
);
create
table
ten
(
a
int
);
...
@@ -433,7 +469,10 @@ create table t1 (
...
@@ -433,7 +469,10 @@ create table t1 (
insert
into
t1
select
a
,
a
,
a
,
a
from
ten
;
insert
into
t1
select
a
,
a
,
a
,
a
from
ten
;
explain
select
*
from
t1
force
index
(
a_b_c
)
where
a
between
1
and
4
and
b
<
50
;
explain
select
*
from
t1
force
index
(
a_b_c
)
where
a
between
1
and
4
and
b
<
50
;
#Enable after fix MDEV-32034
--
disable_view_protocol
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
ten
,
t1
;
drop
table
ten
,
t1
;
--
echo
# Ported test from MYSQL for ranges involving Binary column
--
echo
# Ported test from MYSQL for ranges involving Binary column
...
@@ -442,11 +481,14 @@ CREATE TABLE t1(i INT PRIMARY KEY, b BINARY(16), INDEX i_b(b));
...
@@ -442,11 +481,14 @@ CREATE TABLE t1(i INT PRIMARY KEY, b BINARY(16), INDEX i_b(b));
INSERT
INTO
t1
VALUES
(
1
,
x
'D95B94336A9946A39CF5B58CFE772D8C'
);
INSERT
INTO
t1
VALUES
(
1
,
x
'D95B94336A9946A39CF5B58CFE772D8C'
);
INSERT
INTO
t1
VALUES
(
2
,
NULL
);
INSERT
INTO
t1
VALUES
(
2
,
NULL
);
#Enable after fix MDEV-32034
--
disable_view_protocol
EXPLAIN
SELECT
*
FROM
t1
WHERE
b
IN
(
0xD95B94336A9946A39CF5B58CFE772D8C
);
EXPLAIN
SELECT
*
FROM
t1
WHERE
b
IN
(
0xD95B94336A9946A39CF5B58CFE772D8C
);
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
EXPLAIN
SELECT
*
FROM
t1
WHERE
b
IS
NULL
;
EXPLAIN
SELECT
*
FROM
t1
WHERE
b
IS
NULL
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t1
;
drop
table
t1
;
...
@@ -459,6 +501,8 @@ INSERT INTO t1 VALUES (1, 'ab\n');
...
@@ -459,6 +501,8 @@ INSERT INTO t1 VALUES (1, 'ab\n');
INSERT
INTO
t1
VALUES
(
2
,
NULL
);
INSERT
INTO
t1
VALUES
(
2
,
NULL
);
set
optimizer_trace
=
1
;
set
optimizer_trace
=
1
;
EXPLAIN
SELECT
*
FROM
t1
WHERE
b
=
'ab\n'
;
EXPLAIN
SELECT
*
FROM
t1
WHERE
b
=
'ab\n'
;
#Enable after fix MDEV-32034
--
disable_view_protocol
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
ALTER
TABLE
t1
modify
column
b
BINARY
(
10
)
AFTER
i
;
ALTER
TABLE
t1
modify
column
b
BINARY
(
10
)
AFTER
i
;
...
@@ -502,6 +546,7 @@ insert into t1 select date_add(now(), interval a day), date_add(now(), interval
...
@@ -502,6 +546,7 @@ insert into t1 select date_add(now(), interval a day), date_add(now(), interval
--
enable_warnings
--
enable_warnings
explain
format
=
json
select
*
from
t1
force
index
(
start_date
)
where
start_date
>=
'2019-02-10'
and
end_date
<
'2019-04-01'
;
explain
format
=
json
select
*
from
t1
force
index
(
start_date
)
where
start_date
>=
'2019-02-10'
and
end_date
<
'2019-04-01'
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t1
,
t0
,
one_k
;
drop
table
t1
,
t0
,
one_k
;
--
echo
#
--
echo
#
...
@@ -533,13 +578,19 @@ set optimizer_trace=1;
...
@@ -533,13 +578,19 @@ set optimizer_trace=1;
--
echo
# but for joins using condition selectivity it is not as trivial. So,
--
echo
# but for joins using condition selectivity it is not as trivial. So,
--
echo
# now we are printing it)
--
echo
# now we are printing it)
explain
select
*
from
t0
A
,
one_k
B
where
A
.
a
<
5
and
B
.
a
<
800
;
explain
select
*
from
t0
A
,
one_k
B
where
A
.
a
<
5
and
B
.
a
<
800
;
#Enable after fix MDEV-32034
--
disable_view_protocol
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.considered_execution_plans'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.considered_execution_plans'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
set
join_cache_level
=@
tmp_jcl
;
set
join_cache_level
=@
tmp_jcl
;
--
echo
# This shows post-join selectivity
--
echo
# This shows post-join selectivity
explain
select
*
from
t0
A
,
one_k
B
where
A
.
a
=
B
.
b
and
B
.
a
<
800
;
explain
select
*
from
t0
A
,
one_k
B
where
A
.
a
=
B
.
b
and
B
.
a
<
800
;
#Enable after fix MDEV-32034
--
disable_view_protocol
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.considered_execution_plans'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.considered_execution_plans'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t0
,
one_k
;
drop
table
t0
,
one_k
;
--
echo
#
--
echo
#
...
@@ -551,7 +602,10 @@ insert into t1 values ('foo'), ('bar');
...
@@ -551,7 +602,10 @@ insert into t1 values ('foo'), ('bar');
EXPLAIN
SELECT
*
FROM
t1
WHERE
a
=
REPEAT
(
'a'
,
0
);
EXPLAIN
SELECT
*
FROM
t1
WHERE
a
=
REPEAT
(
'a'
,
0
);
SELECT
*
FROM
t1
WHERE
a
=
REPEAT
(
'a'
,
0
);
SELECT
*
FROM
t1
WHERE
a
=
REPEAT
(
'a'
,
0
);
#Enable after fix MDEV-32034
--
disable_view_protocol
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
DROP
TABLE
t1
;
DROP
TABLE
t1
;
--
echo
#
--
echo
#
...
@@ -569,7 +623,10 @@ insert into t3 values (1),(2),(3),(4),(5),(6),(7),(8),(9),(10);
...
@@ -569,7 +623,10 @@ insert into t3 values (1),(2),(3),(4),(5),(6),(7),(8),(9),(10);
explain
explain
select
*
from
t3
where
(
a
,
a
)
in
(
select
t1
.
a
,
t2
.
a
from
t1
,
t2
where
t1
.
b
=
t2
.
b
);
select
*
from
t3
where
(
a
,
a
)
in
(
select
t1
.
a
,
t2
.
a
from
t1
,
t2
where
t1
.
b
=
t2
.
b
);
#Enable after fix MDEV-32034
--
disable_view_protocol
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.semijoin_table_pullout'
))
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.semijoin_table_pullout'
))
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t1
,
t2
,
t3
;
drop
table
t1
,
t2
,
t3
;
...
@@ -581,7 +638,10 @@ create table t1 (kp1 int, kp2 int, key(kp1, kp2));
...
@@ -581,7 +638,10 @@ create table t1 (kp1 int, kp2 int, key(kp1, kp2));
insert
into
t1
values
(
1
,
1
),(
1
,
5
),(
5
,
1
),(
5
,
5
);
insert
into
t1
values
(
1
,
1
),(
1
,
5
),(
5
,
1
),(
5
,
5
);
set
optimizer_trace
=
1
;
set
optimizer_trace
=
1
;
select
*
from
t1
force
index
(
kp1
)
where
(
kp1
=
2
and
kp2
>=
4
);
select
*
from
t1
force
index
(
kp1
)
where
(
kp1
=
2
and
kp2
>=
4
);
#Enable after fix MDEV-32034
--
disable_view_protocol
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.range_scan_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.range_scan_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t1
;
drop
table
t1
;
--
echo
#
--
echo
#
...
@@ -595,7 +655,10 @@ INSERT INTO t2 SELECT seq, seq from seq_1_to_100;
...
@@ -595,7 +655,10 @@ INSERT INTO t2 SELECT seq, seq from seq_1_to_100;
SET
OPTIMIZER_TRACE
=
1
;
SET
OPTIMIZER_TRACE
=
1
;
EXPLAIN
SELECT
*
FROM
t1
,
t2
WHERE
t1
.
a
=
t2
.
a
ORDER
BY
t2
.
b
;
EXPLAIN
SELECT
*
FROM
t1
,
t2
WHERE
t1
.
a
=
t2
.
a
ORDER
BY
t2
.
b
;
#Enable after fix MDEV-32034
--
disable_view_protocol
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.considered_execution_plans'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.considered_execution_plans'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
DROP
TABLE
t1
,
t2
;
DROP
TABLE
t1
,
t2
;
--
echo
#
--
echo
#
...
@@ -607,12 +670,15 @@ CREATE TABLE t1(a INT, b INT);
...
@@ -607,12 +670,15 @@ CREATE TABLE t1(a INT, b INT);
INSERT
INTO
t1
SELECT
seq
,
seq
from
seq_1_to_100
;
INSERT
INTO
t1
SELECT
seq
,
seq
from
seq_1_to_100
;
SET
optimizer_trace
=
1
;
SET
optimizer_trace
=
1
;
ANALYZE
TABLE
t1
PERSISTENT
FOR
ALL
;
ANALYZE
TABLE
t1
PERSISTENT
FOR
ALL
;
#Enable after fix MDEV-32034
--
disable_view_protocol
EXPLAIN
EXTENDED
SELECT
*
from
t1
WHERE
a
between
1
and
5
and
b
<=
5
;
EXPLAIN
EXTENDED
SELECT
*
from
t1
WHERE
a
between
1
and
5
and
b
<=
5
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.selectivity_for_columns'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.selectivity_for_columns'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
EXPLAIN
EXTENDED
SELECT
*
from
t1
WHERE
a
!=
5
;
EXPLAIN
EXTENDED
SELECT
*
from
t1
WHERE
a
!=
5
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.selectivity_for_columns'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.selectivity_for_columns'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
EXPLAIN
EXTENDED
SELECT
*
from
t1
WHERE
b
>=
10
and
b
<
25
;
EXPLAIN
EXTENDED
SELECT
*
from
t1
WHERE
b
>=
10
and
b
<
25
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.selectivity_for_columns'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.selectivity_for_columns'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t1
;
drop
table
t1
;
--
echo
#
--
echo
#
...
@@ -623,7 +689,10 @@ drop table t1;
...
@@ -623,7 +689,10 @@ drop table t1;
CREATE
TABLE
t1
(
a
INT
,
b
INT
,
PRIMARY
KEY
(
a
)
);
CREATE
TABLE
t1
(
a
INT
,
b
INT
,
PRIMARY
KEY
(
a
)
);
SELECT
sum
(
b
),
row_number
()
OVER
(
order
by
b
)
FROM
t1
WHERE
a
=
101
;
SELECT
sum
(
b
),
row_number
()
OVER
(
order
by
b
)
FROM
t1
WHERE
a
=
101
;
UPDATE
t1
SET
b
=
10
WHERE
a
=
1
;
UPDATE
t1
SET
b
=
10
WHERE
a
=
1
;
#Enable after fix MDEV-32034
--
disable_view_protocol
SELECT
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.range_scan_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
SELECT
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.range_scan_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
DROP
TABLE
t1
;
DROP
TABLE
t1
;
set
optimizer_trace
=
'enabled=off'
;
set
optimizer_trace
=
'enabled=off'
;
...
@@ -684,10 +753,13 @@ where
...
@@ -684,10 +753,13 @@ where
c5
in
(
1
,
2
,
3
,
4
,
5
,
6
,
7
,
8
,
9
,
10
)
and
c5
in
(
1
,
2
,
3
,
4
,
5
,
6
,
7
,
8
,
9
,
10
)
and
c6
in
(
1
,
2
,
3
,
4
);
c6
in
(
1
,
2
,
3
,
4
);
#Enable after fix MDEV-32034
--
disable_view_protocol
select
select
json_detailed
(
json_extract
(
trace
,
'$**.setup_range_conditions'
))
json_detailed
(
json_extract
(
trace
,
'$**.setup_range_conditions'
))
from
from
information_schema
.
optimizer_trace
;
information_schema
.
optimizer_trace
;
--
enable_view_protocol
drop
table
t1
;
drop
table
t1
;
...
@@ -701,7 +773,9 @@ CREATE TABLE t (a int, b int);
...
@@ -701,7 +773,9 @@ CREATE TABLE t (a int, b int);
CREATE
VIEW
v
AS
SELECT
1
AS
c
UNION
SELECT
2
AS
c
;
CREATE
VIEW
v
AS
SELECT
1
AS
c
UNION
SELECT
2
AS
c
;
INSERT
INTO
t
VALUES
(
0
,
4
),(
5
,
6
);
INSERT
INTO
t
VALUES
(
0
,
4
),(
5
,
6
);
UPDATE
t
,
v
SET
t
.
b
=
t
.
a
,
t
.
a
=
v
.
c
WHERE
v
.
c
<
t
.
a
;
UPDATE
t
,
v
SET
t
.
b
=
t
.
a
,
t
.
a
=
v
.
c
WHERE
v
.
c
<
t
.
a
;
--
disable_view_protocol
SELECT
*
FROM
information_schema
.
optimizer_trace
;
SELECT
*
FROM
information_schema
.
optimizer_trace
;
--
enable_view_protocol
SELECT
*
FROM
t
;
SELECT
*
FROM
t
;
...
@@ -794,11 +868,14 @@ set optimizer_trace=DEFAULT;
...
@@ -794,11 +868,14 @@ set optimizer_trace=DEFAULT;
--
echo
# MDEV-29179 Condition pushdown from HAVING into WHERE is not shown in optimizer trace
--
echo
# MDEV-29179 Condition pushdown from HAVING into WHERE is not shown in optimizer trace
--
echo
#
--
echo
#
#Enable after fix MDEV-32034
--
disable_view_protocol
CREATE
TABLE
t1
(
a
INT
,
b
VARCHAR
(
1
),
KEY
(
a
),
KEY
(
b
,
a
))
ENGINE
=
MEMORY
;
CREATE
TABLE
t1
(
a
INT
,
b
VARCHAR
(
1
),
KEY
(
a
),
KEY
(
b
,
a
))
ENGINE
=
MEMORY
;
INSERT
INTO
t1
VALUES
(
4
,
'n'
),(
1
,
'h'
),(
NULL
,
'w'
);
INSERT
INTO
t1
VALUES
(
4
,
'n'
),(
1
,
'h'
),(
NULL
,
'w'
);
SET
optimizer_trace
=
'enabled=on'
;
SET
optimizer_trace
=
'enabled=on'
;
SELECT
b
,
a
FROM
t1
WHERE
b
<>
'p'
OR
a
=
4
GROUP
BY
b
,
a
HAVING
a
<=
7
;
SELECT
json_detailed
(
json_extract
(
trace
,
'$**.steps[*].join_optimization.steps[*].condition_pushdown_from_having'
)
)
exp1
,
JSON_VALID
(
trace
)
exp2
FROM
information_schema
.
optimizer_trace
;
SELECT
b
,
a
FROM
t1
WHERE
b
<>
'p'
OR
a
=
4
GROUP
BY
b
,
a
HAVING
a
<=
7
;
SELECT
json_detailed
(
json_extract
(
trace
,
'$**.steps[*].join_optimization.steps[*].condition_pushdown_from_having'
)
)
exp1
,
JSON_VALID
(
trace
)
exp2
FROM
information_schema
.
optimizer_trace
;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
--
enable_view_protocol
--
echo
#
--
echo
#
--
echo
# End of 10.4 tests
--
echo
# End of 10.4 tests
...
@@ -833,8 +910,11 @@ insert into t3 select a,a from t0;
...
@@ -833,8 +910,11 @@ insert into t3 select a,a from t0;
explain
explain
select
*
from
t1
left
join
(
t2
join
t3
on
t3
.
pk
=
1000
)
on
t2
.
a
=
t1
.
a
and
t2
.
pk
is
null
;
select
*
from
t1
left
join
(
t2
join
t3
on
t3
.
pk
=
1000
)
on
t2
.
a
=
t1
.
a
and
t2
.
pk
is
null
;
#Enable after fix MDEV-32034
--
disable_view_protocol
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.mark_join_nest_as_const'
))
as
jd
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.mark_join_nest_as_const'
))
as
jd
from
information_schema
.
optimizer_trace
;
from
information_schema
.
optimizer_trace
;
--
disable_view_protocol
drop
table
t0
,
t1
,
t2
,
t3
;
drop
table
t0
,
t1
,
t2
,
t3
;
...
@@ -850,17 +930,27 @@ set in_predicate_conversion_threshold=3;
...
@@ -850,17 +930,27 @@ set in_predicate_conversion_threshold=3;
explain
select
*
from
t0
where
a
in
(
1
,
2
,
3
,
4
,
5
,
6
);
explain
select
*
from
t0
where
a
in
(
1
,
2
,
3
,
4
,
5
,
6
);
#Enable after fix MDEV-32034
--
disable_view_protocol
select
json_detailed
(
json_extract
(
trace
,
'$**.in_to_subquery_conversion'
))
as
jd
select
json_detailed
(
json_extract
(
trace
,
'$**.in_to_subquery_conversion'
))
as
jd
from
information_schema
.
optimizer_trace
;
from
information_schema
.
optimizer_trace
;
--
enable_view_protocol
explain
select
*
from
t0
where
a
in
(
1
,
2
,
3
,
4
,
5
,
a
+
1
);
explain
select
*
from
t0
where
a
in
(
1
,
2
,
3
,
4
,
5
,
a
+
1
);
#Enable after fix MDEV-32034
--
disable_view_protocol
select
json_detailed
(
json_extract
(
trace
,
'$**.in_to_subquery_conversion'
))
as
jd
select
json_detailed
(
json_extract
(
trace
,
'$**.in_to_subquery_conversion'
))
as
jd
from
information_schema
.
optimizer_trace
;
from
information_schema
.
optimizer_trace
;
--
enable_view_protocol
explain
select
*
from
t0
where
a
in
(
'1'
,
'2'
,
'3'
,
'4'
,
'5'
,
'6'
);
explain
select
*
from
t0
where
a
in
(
'1'
,
'2'
,
'3'
,
'4'
,
'5'
,
'6'
);
#Enable after fix MDEV-32034
--
disable_view_protocol
select
json_detailed
(
json_extract
(
trace
,
'$**.in_to_subquery_conversion'
))
as
jd
select
json_detailed
(
json_extract
(
trace
,
'$**.in_to_subquery_conversion'
))
as
jd
from
information_schema
.
optimizer_trace
;
from
information_schema
.
optimizer_trace
;
--
enable_view_protocol
set
in_predicate_conversion_threshold
=@
tmp
;
set
in_predicate_conversion_threshold
=@
tmp
;
drop
table
t0
;
drop
table
t0
;
...
@@ -875,7 +965,9 @@ set optimizer_trace=1;
...
@@ -875,7 +965,9 @@ set optimizer_trace=1;
insert
into
t2
select
*
from
t1
where
a
<=
b
and
a
>
4
;
insert
into
t2
select
*
from
t1
where
a
<=
b
and
a
>
4
;
--
disable_view_protocol
select
QUERY
,
LENGTH
(
trace
)
>
1
from
information_schema
.
optimizer_trace
;
select
QUERY
,
LENGTH
(
trace
)
>
1
from
information_schema
.
optimizer_trace
;
--
enable_view_protocol
drop
table
t1
,
t2
;
drop
table
t1
,
t2
;
...
...
mysql-test/main/opt_trace_index_merge.test
View file @
090cecd5
...
@@ -15,7 +15,9 @@ from t0 A, t0 B, t0 C;
...
@@ -15,7 +15,9 @@ from t0 A, t0 B, t0 C;
--
echo
This
should
use
union
:
--
echo
This
should
use
union
:
explain select * from t1 where a=1 or b=1
;
explain select * from t1 where a=1 or b=1
;
--
disable_view_protocol
select
*
from
information_schema
.
OPTIMIZER_TRACE
;
select
*
from
information_schema
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t0
,
t1
;
drop
table
t0
,
t1
;
set
optimizer_trace
=
"enabled=off"
;
set
optimizer_trace
=
"enabled=off"
;
set
@@
optimizer_switch
=
@
tmp_opt_switch
;
set
@@
optimizer_switch
=
@
tmp_opt_switch
;
...
...
mysql-test/main/opt_trace_index_merge_innodb.test
View file @
090cecd5
...
@@ -33,7 +33,9 @@ set optimizer_trace="enabled=on";
...
@@ -33,7 +33,9 @@ set optimizer_trace="enabled=on";
set
@
tmp_index_merge_ror_cpk
=@@
optimizer_switch
;
set
@
tmp_index_merge_ror_cpk
=@@
optimizer_switch
;
set
optimizer_switch
=
'extended_keys=off'
;
set
optimizer_switch
=
'extended_keys=off'
;
explain
select
*
from
t1
where
pk1
!=
0
and
key1
=
1
;
explain
select
*
from
t1
where
pk1
!=
0
and
key1
=
1
;
--
disable_view_protocol
select
*
from
information_schema
.
OPTIMIZER_TRACE
;
select
*
from
information_schema
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t1
;
drop
table
t1
;
set
@@
optimizer_switch
=
@
tmp_index_merge_ror_cpk
;
set
@@
optimizer_switch
=
@
tmp_index_merge_ror_cpk
;
...
...
mysql-test/main/opt_trace_ucs2.test
View file @
090cecd5
...
@@ -6,5 +6,8 @@ insert into t1 values ('a', 'a');
...
@@ -6,5 +6,8 @@ insert into t1 values ('a', 'a');
insert
into
t1
values
(
'a'
,
'a'
);
insert
into
t1
values
(
'a'
,
'a'
);
set
optimizer_trace
=
1
;
set
optimizer_trace
=
1
;
explain
format
=
json
select
*
from
t1
force
index
(
col1
)
where
col1
>=
'a'
;
explain
format
=
json
select
*
from
t1
force
index
(
col1
)
where
col1
>=
'a'
;
# Enable after fix MDEV-31408
--
disable_view_protocol
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
select
JSON_DETAILED
(
JSON_EXTRACT
(
trace
,
'$**.analyzing_range_alternatives'
))
AS
JS
from
INFORMATION_SCHEMA
.
OPTIMIZER_TRACE
;
--
enable_view_protocol
drop
table
t1
;
drop
table
t1
;
mysql-test/main/range_notembedded.test
View file @
090cecd5
...
@@ -26,8 +26,11 @@ explain select * from t2 where key1 in (1,2,3) and pk not in (1,2,3);
...
@@ -26,8 +26,11 @@ explain select * from t2 where key1 in (1,2,3) and pk not in (1,2,3);
--
echo
# This should show only ranges in form "(1) <= (key1) <= (1)"
--
echo
# This should show only ranges in form "(1) <= (key1) <= (1)"
--
echo
# ranges over "pk" should not be constructed.
--
echo
# ranges over "pk" should not be constructed.
# Enable after fix MDEV-31408
--
disable_view_protocol
select
json_detailed
(
JSON_EXTRACT
(
trace
,
'$**.ranges'
))
select
json_detailed
(
JSON_EXTRACT
(
trace
,
'$**.ranges'
))
from
information_schema
.
optimizer_trace
;
from
information_schema
.
optimizer_trace
;
--
enable_view_protocol
set
optimizer_trace
=@
tmp_21958
;
set
optimizer_trace
=@
tmp_21958
;
drop
table
t2
;
drop
table
t2
;
...
...
mysql-test/main/selectivity_notembedded.test
View file @
090cecd5
...
@@ -98,9 +98,12 @@ set @tmp=@@optimizer_trace;
...
@@ -98,9 +98,12 @@ set @tmp=@@optimizer_trace;
set
optimizer_trace
=
1
;
set
optimizer_trace
=
1
;
explain
select
*
from
t10
where
a
in
(
91303
);
explain
select
*
from
t10
where
a
in
(
91303
);
#Enable after fix MDEV-32034
--
disable_view_protocol
--
echo
# Must have selectivity_from_histogram <= 1.0:
--
echo
# Must have selectivity_from_histogram <= 1.0:
select
json_detailed
(
json_extract
(
trace
,
'$**.selectivity_for_columns'
))
as
sel
select
json_detailed
(
json_extract
(
trace
,
'$**.selectivity_for_columns'
))
as
sel
from
information_schema
.
optimizer_trace
;
from
information_schema
.
optimizer_trace
;
--
enable_view_protocol
set
optimizer_trace
=@
tmp
;
set
optimizer_trace
=@
tmp
;
drop
table
t0
,
t1
,
t10
;
drop
table
t0
,
t1
,
t10
;
...
@@ -169,17 +172,23 @@ while ($i < $N_CONDS) {
...
@@ -169,17 +172,23 @@ while ($i < $N_CONDS) {
#echo $query_tbl;
#echo $query_tbl;
evalp
$query_tbl
;
evalp
$query_tbl
;
#Enable after fix MDEV-32034
--
disable_view_protocol
select
select
json_detailed
(
json_extract
(
trace
,
'$**.selectivity_for_columns[0]'
))
as
JS
json_detailed
(
json_extract
(
trace
,
'$**.selectivity_for_columns[0]'
))
as
JS
from
from
information_schema
.
optimizer_trace
;
information_schema
.
optimizer_trace
;
--
enable_view_protocol
evalp
$query_tbl
;
evalp
$query_tbl
;
#Enable after fix MDEV-32034
--
disable_view_protocol
eval
select
eval
select
json_detailed
(
json_extract
(
trace
,
'\$**.selectivity_for_columns[$N_LAST_COND]'
))
as
JS
json_detailed
(
json_extract
(
trace
,
'\$**.selectivity_for_columns[$N_LAST_COND]'
))
as
JS
from
from
information_schema
.
optimizer_trace
;
information_schema
.
optimizer_trace
;
--
enable_view_protocol
--
echo
#
--
echo
#
--
echo
# Check if not being able to infer anything for the first MAX_KEY
--
echo
# Check if not being able to infer anything for the first MAX_KEY
...
@@ -200,10 +209,13 @@ let $query_tbl= $query_tbl) and col$N_LAST_COND>1;
...
@@ -200,10 +209,13 @@ let $query_tbl= $query_tbl) and col$N_LAST_COND>1;
#echo $query_tbl;
#echo $query_tbl;
evalp
$query_tbl
;
evalp
$query_tbl
;
#Enable after fix MDEV-32034
--
disable_view_protocol
select
select
json_detailed
(
json_extract
(
trace
,
'$**.selectivity_for_columns'
))
as
JS
json_detailed
(
json_extract
(
trace
,
'$**.selectivity_for_columns'
))
as
JS
from
from
information_schema
.
optimizer_trace
;
information_schema
.
optimizer_trace
;
--
enable_view_protocol
set
optimizer_trace
=@
trace_tmp
;
set
optimizer_trace
=@
trace_tmp
;
drop
table
t1
;
drop
table
t1
;
...
...
mysql-test/main/subselect.test
View file @
090cecd5
...
@@ -338,7 +338,10 @@ CREATE TABLE `t1` (
...
@@ -338,7 +338,10 @@ CREATE TABLE `t1` (
SELECT
(
SELECT
numeropost
FROM
t1
HAVING
numreponse
=
a
),
numreponse
FROM
(
SELECT
*
FROM
t1
)
as
a
;
SELECT
(
SELECT
numeropost
FROM
t1
HAVING
numreponse
=
a
),
numreponse
FROM
(
SELECT
*
FROM
t1
)
as
a
;
--
error
ER_BAD_FIELD_ERROR
--
error
ER_BAD_FIELD_ERROR
SELECT
numreponse
,
(
SELECT
numeropost
FROM
t1
HAVING
numreponse
=
a
)
FROM
(
SELECT
*
FROM
t1
)
as
a
;
SELECT
numreponse
,
(
SELECT
numeropost
FROM
t1
HAVING
numreponse
=
a
)
FROM
(
SELECT
*
FROM
t1
)
as
a
;
#Enable after fix MDEV-31937
--
disable_ps2_protocol
SELECT
numreponse
,
(
SELECT
numeropost
FROM
t1
HAVING
numreponse
=
1
)
FROM
(
SELECT
*
FROM
t1
)
as
a
;
SELECT
numreponse
,
(
SELECT
numeropost
FROM
t1
HAVING
numreponse
=
1
)
FROM
(
SELECT
*
FROM
t1
)
as
a
;
--
enable_ps2_protocol
INSERT
INTO
t1
(
numeropost
,
numreponse
,
pseudo
)
VALUES
(
1
,
1
,
'joce'
),(
1
,
2
,
'joce'
),(
1
,
3
,
'test'
);
INSERT
INTO
t1
(
numeropost
,
numreponse
,
pseudo
)
VALUES
(
1
,
1
,
'joce'
),(
1
,
2
,
'joce'
),(
1
,
3
,
'test'
);
--
error
ER_SUBQUERY_NO_1_ROW
--
error
ER_SUBQUERY_NO_1_ROW
EXPLAIN
EXTENDED
SELECT
numreponse
FROM
t1
WHERE
numeropost
=
'1'
AND
numreponse
=
(
SELECT
1
FROM
t1
WHERE
numeropost
=
'1'
);
EXPLAIN
EXTENDED
SELECT
numreponse
FROM
t1
WHERE
numeropost
=
'1'
AND
numreponse
=
(
SELECT
1
FROM
t1
WHERE
numeropost
=
'1'
);
...
@@ -2998,10 +3001,13 @@ SELECT a, AVG(b),
...
@@ -2998,10 +3001,13 @@ SELECT a, AVG(b),
(
SELECT
t
.
c
FROM
t1
AS
t
WHERE
t1
.
a
=
t
.
a
AND
t
.
b
=
AVG
(
t1
.
b
))
AS
test
(
SELECT
t
.
c
FROM
t1
AS
t
WHERE
t1
.
a
=
t
.
a
AND
t
.
b
=
AVG
(
t1
.
b
))
AS
test
FROM
t1
WHERE
t1
.
d
=
0
GROUP
BY
a
;
FROM
t1
WHERE
t1
.
d
=
0
GROUP
BY
a
;
# Enable after fix MDEV-32038
--
disable_ps2_protocol
SELECT
tt
.
a
,
SELECT
tt
.
a
,
(
SELECT
(
SELECT
c
FROM
t1
as
t
WHERE
t1
.
a
=
t
.
a
AND
t
.
d
=
MAX
(
t1
.
b
+
tt
.
a
)
(
SELECT
(
SELECT
c
FROM
t1
as
t
WHERE
t1
.
a
=
t
.
a
AND
t
.
d
=
MAX
(
t1
.
b
+
tt
.
a
)
LIMIT
1
)
FROM
t1
WHERE
t1
.
a
=
tt
.
a
GROUP
BY
a
LIMIT
1
)
as
test
LIMIT
1
)
FROM
t1
WHERE
t1
.
a
=
tt
.
a
GROUP
BY
a
LIMIT
1
)
as
test
FROM
t1
as
tt
;
FROM
t1
as
tt
;
--
enable_ps2_protocol
SELECT
tt
.
a
,
SELECT
tt
.
a
,
(
SELECT
(
SELECT
t
.
c
FROM
t1
AS
t
WHERE
t1
.
a
=
t
.
a
AND
t
.
d
=
MAX
(
t1
.
b
+
tt
.
a
)
(
SELECT
(
SELECT
t
.
c
FROM
t1
AS
t
WHERE
t1
.
a
=
t
.
a
AND
t
.
d
=
MAX
(
t1
.
b
+
tt
.
a
)
...
...
mysql-test/main/temp_table_symlink.test
View file @
090cecd5
...
@@ -23,8 +23,10 @@ error 1,1030;
...
@@ -23,8 +23,10 @@ error 1,1030;
create
temporary
table
t2
(
a
int
);
create
temporary
table
t2
(
a
int
);
error
1
,
1030
;
error
1
,
1030
;
create
temporary
table
t3
(
a
int
)
engine
=
Aria
;
create
temporary
table
t3
(
a
int
)
engine
=
Aria
;
--
disable_view_protocol
error
1
,
1030
;
error
1
,
1030
;
select
*
from
information_schema
.
columns
where
table_schema
=
'test'
;
select
*
from
information_schema
.
columns
where
table_schema
=
'test'
;
--
enable_view_protocol
flush
tables
;
flush
tables
;
select
*
from
d1
;
select
*
from
d1
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment