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
6acca3f7
Commit
6acca3f7
authored
Oct 05, 2019
by
Varun Gupta
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Sort nest not allowed inside dependent subqueries
parent
f8349447
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
184 additions
and
7 deletions
+184
-7
mysql-test/main/sort_nest.result
mysql-test/main/sort_nest.result
+119
-3
mysql-test/main/sort_nest.test
mysql-test/main/sort_nest.test
+63
-3
sql/sql_sort_nest.cc
sql/sql_sort_nest.cc
+2
-1
No files found.
mysql-test/main/sort_nest.result
View file @
6acca3f7
...
...
@@ -1794,14 +1794,16 @@ drop table t0,t1,t2;
#
CREATE TABLE t0 (a int);
INSERT INTO t0 SELECT seq-1 from seq_1_to_10;
CREATE TABLE t1 (a int, b int);
INSERT INTO t1 SELECT a, a from t0 where a <5;
CREATE TABLE t1 (a int, b int
, c int
);
INSERT INTO t1 SELECT a, a
, a
from t0 where a <5;
CREATE TABLE t2 as SELECT * from t1 where a < 5;
CREATE TABLE t3(a int, b int, c int, key(a));
INSERT INTO t3 SELECT seq-1, seq-1, seq-1 from seq_1_to_10;
CREATE TABLE t4 as SELECT * from t1 where a < 5;
ANALYZE TABLE t1 PERSISTENT FOR ALL;
ANALYZE TABLE t2 PERSISTENT FOR ALL;
ANALYZE TABLE t3 PERSISTENT FOR ALL;
ANALYZE TABLE t4 PERSISTENT FOR ALL;
set use_sort_nest=1;
EXPLAIN SELECT t1.a, t2.b, t1.b, t1.b + t2.b
FROM t1,t2, t3
...
...
@@ -2120,4 +2122,118 @@ a b b t1.b + t2.b
2 2 2 4
3 3 3 6
4 4 4 8
drop table t0,t1,t2,t3;
#
# Dependent subqueries cannot have a sort-nest
#
set use_sort_nest=1;
EXPLAIN SELECT *
FROM t1
WHERE
t1.b = (select t2.b from t2,t3,t4
where t2.a=t1.a and t3.b=t4.b
ORDER BY t2.c,t3.c limit 1);
id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY t1 ALL NULL NULL NULL NULL 5 Using where
2 DEPENDENT SUBQUERY t2 ALL NULL NULL NULL NULL 5 Using where; Using temporary; Using filesort
2 DEPENDENT SUBQUERY t4 ALL NULL NULL NULL NULL 5 Using join buffer (flat, BNL join)
2 DEPENDENT SUBQUERY t3 ALL NULL NULL NULL NULL 10 Using where; Using join buffer (incremental, BNL join)
SELECT *
FROM t1
WHERE
t1.b = (select t2.b from t2,t3,t4
where t2.a=t1.a and t3.b=t4.b
ORDER BY t2.c,t3.c limit 1);
a b c
0 0 0
1 1 1
2 2 2
3 3 3
4 4 4
set use_sort_nest= 0;
SELECT *
FROM t1
WHERE
t1.b = (select t2.b from t2,t3,t4
where t2.a=t1.a and t3.b=t4.b
ORDER BY t2.c,t3.c limit 1);
a b c
0 0 0
1 1 1
2 2 2
3 3 3
4 4 4
#
# Independent subqueries can have a sort-nest
#
set use_sort_nest=1;
EXPLAIN SELECT *
FROM t1
WHERE
t1.b = (select t2.b from t2,t3,t4
where t2.a=t3.a and t3.b=t4.b
ORDER BY t2.c,t3.c limit 1);
id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY t1 ALL NULL NULL NULL NULL 5 Using where
2 SUBQUERY t2 ALL NULL NULL NULL NULL 5 Using where
2 SUBQUERY t3 ref a a 5 test.t2.a 1
2 SUBQUERY <sort-nest> ALL NULL NULL NULL NULL 1 Using filesort
2 SUBQUERY t4 ALL NULL NULL NULL NULL 5 Using where
SELECT *
FROM t1
WHERE
t1.b = (select t2.b from t2,t3,t4
where t2.a=t3.a and t3.b=t4.b
ORDER BY t2.c,t3.c limit 1);
a b c
0 0 0
set use_sort_nest= 0;
SELECT *
FROM t1
WHERE
t1.b = (select t2.b from t2,t3,t4
where t2.a=t3.a and t3.b=t4.b
ORDER BY t2.c,t3.c limit 1);
a b c
0 0 0
#
# Sort nest inside a derived table
#
set use_sort_nest=1;
EXPLAIN SELECT *
FROM (SELECT t1.a as t, t2.b as u, t1.b as v, t3.a as x
FROM t1,t2,t3
WHERE t1.a=t2.a AND t2.b=t3.a
ORDER BY t2.b DESC, t1.b DESC
LIMIT 5)q;
id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY <derived2> ALL NULL NULL NULL NULL 5
2 DERIVED t1 ALL NULL NULL NULL NULL 5
2 DERIVED t2 ALL NULL NULL NULL NULL 5 Using where; Using join buffer (flat, BNL join)
2 DERIVED <sort-nest> ALL NULL NULL NULL NULL 5 Using filesort
2 DERIVED t3 ref a a 5 sort-nest.b 1 Using index
SELECT *
FROM (SELECT t1.a as t, t2.b as u, t1.b as v, t3.a as x
FROM t1,t2,t3
WHERE t1.a=t2.a AND t2.b=t3.a
ORDER BY t2.b DESC, t1.b DESC
LIMIT 5)q;
t u v x
4 4 4 4
3 3 3 3
2 2 2 2
1 1 1 1
0 0 0 0
set use_sort_nest=0;
SELECT *
FROM (SELECT t1.a as t, t2.b as u, t1.b as v, t3.a as x
FROM t1,t2,t3
WHERE t1.a=t2.a AND t2.b=t3.a
ORDER BY t2.b DESC, t1.b DESC
LIMIT 5)q;
t u v x
4 4 4 4
3 3 3 3
2 2 2 2
1 1 1 1
0 0 0 0
drop table t0,t1,t2,t3,t4;
mysql-test/main/sort_nest.test
View file @
6acca3f7
...
...
@@ -575,16 +575,18 @@ drop table t0,t1,t2;
CREATE
TABLE
t0
(
a
int
);
INSERT
INTO
t0
SELECT
seq
-
1
from
seq_1_to_10
;
CREATE
TABLE
t1
(
a
int
,
b
int
);
INSERT
INTO
t1
SELECT
a
,
a
from
t0
where
a
<
5
;
CREATE
TABLE
t1
(
a
int
,
b
int
,
c
int
);
INSERT
INTO
t1
SELECT
a
,
a
,
a
from
t0
where
a
<
5
;
CREATE
TABLE
t2
as
SELECT
*
from
t1
where
a
<
5
;
CREATE
TABLE
t3
(
a
int
,
b
int
,
c
int
,
key
(
a
));
INSERT
INTO
t3
SELECT
seq
-
1
,
seq
-
1
,
seq
-
1
from
seq_1_to_10
;
CREATE
TABLE
t4
as
SELECT
*
from
t1
where
a
<
5
;
--
disable_result_log
ANALYZE
TABLE
t1
PERSISTENT
FOR
ALL
;
ANALYZE
TABLE
t2
PERSISTENT
FOR
ALL
;
ANALYZE
TABLE
t3
PERSISTENT
FOR
ALL
;
ANALYZE
TABLE
t4
PERSISTENT
FOR
ALL
;
--
enable_result_log
...
...
@@ -667,4 +669,62 @@ eval $query;
set
use_sort_nest
=
0
;
eval
$query
;
drop
table
t0
,
t1
,
t2
,
t3
;
--
echo
#
--
echo
# Dependent subqueries cannot have a sort-nest
--
echo
#
let
$query
=
SELECT
*
FROM
t1
WHERE
t1
.
b
=
(
select
t2
.
b
from
t2
,
t3
,
t4
where
t2
.
a
=
t1
.
a
and
t3
.
b
=
t4
.
b
ORDER
BY
t2
.
c
,
t3
.
c
limit
1
);
set
use_sort_nest
=
1
;
eval
EXPLAIN
$query
;
eval
$query
;
set
use_sort_nest
=
0
;
eval
$query
;
--
echo
#
--
echo
# Independent subqueries can have a sort-nest
--
echo
#
let
$query
=
SELECT
*
FROM
t1
WHERE
t1
.
b
=
(
select
t2
.
b
from
t2
,
t3
,
t4
where
t2
.
a
=
t3
.
a
and
t3
.
b
=
t4
.
b
ORDER
BY
t2
.
c
,
t3
.
c
limit
1
);
set
use_sort_nest
=
1
;
eval
EXPLAIN
$query
;
eval
$query
;
set
use_sort_nest
=
0
;
eval
$query
;
--
echo
#
--
echo
# Sort nest inside a derived table
--
echo
#
let
$query
=
SELECT
*
FROM
(
SELECT
t1
.
a
as
t
,
t2
.
b
as
u
,
t1
.
b
as
v
,
t3
.
a
as
x
FROM
t1
,
t2
,
t3
WHERE
t1
.
a
=
t2
.
a
AND
t2
.
b
=
t3
.
a
ORDER
BY
t2
.
b
DESC
,
t1
.
b
DESC
LIMIT
5
)
q
;
set
use_sort_nest
=
1
;
eval
EXPLAIN
$query
;
eval
$query
;
set
use_sort_nest
=
0
;
eval
$query
;
drop
table
t0
,
t1
,
t2
,
t3
,
t4
;
sql/sql_sort_nest.cc
View file @
6acca3f7
...
...
@@ -1422,7 +1422,8 @@ bool JOIN::sort_nest_allowed()
select_lex
->
window_specs
.
elements
>
0
||
select_lex
->
agg_func_used
()
||
select_limit
==
HA_POS_ERROR
||
thd
->
lex
->
sql_command
!=
SQLCOM_SELECT
);
thd
->
lex
->
sql_command
!=
SQLCOM_SELECT
||
select_lex
->
uncacheable
&
UNCACHEABLE_DEPENDENT
);
}
...
...
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