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
befb0bed
Commit
befb0bed
authored
Jun 08, 2020
by
Marko Mäkelä
Browse files
Options
Browse Files
Download
Plain Diff
Merge 10.2 into 10.3
parents
a9bee988
f458b40f
Changes
7
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
252 additions
and
17 deletions
+252
-17
mysql-test/main/cte_recursive.result
mysql-test/main/cte_recursive.result
+163
-7
mysql-test/main/cte_recursive.test
mysql-test/main/cte_recursive.test
+69
-1
sql/sql_cte.cc
sql/sql_cte.cc
+1
-0
sql/sql_derived.cc
sql/sql_derived.cc
+2
-5
sql/sql_union.cc
sql/sql_union.cc
+13
-0
storage/innobase/srv/srv0srv.cc
storage/innobase/srv/srv0srv.cc
+2
-2
storage/innobase/srv/srv0start.cc
storage/innobase/srv/srv0start.cc
+2
-2
No files found.
mysql-test/main/cte_recursive.result
View file @
befb0bed
This diff is collapsed.
Click to expand it.
mysql-test/main/cte_recursive.test
View file @
befb0bed
...
@@ -2424,6 +2424,30 @@ select * from cte1, cte2 where cte1.c1 = 3;
...
@@ -2424,6 +2424,30 @@ select * from cte1, cte2 where cte1.c1 = 3;
eval
$q3
;
eval
$q3
;
let
$q4
=
with
recursive
rcte
(
a
)
as
(
select
1
union
select
cast
(
a
+
1
as
unsigned
)
from
rcte
where
a
<
10
),
cte1
as
(
select
count
(
*
)
as
c1
from
rcte
,
t1
where
a
between
3
and
5
and
id
=
a
-
3
),
cte2
as
(
select
count
(
*
)
as
c2
from
rcte
,
t1
where
a
between
7
and
8
and
id
=
a
-
7
)
select
*
from
cte2
,
cte1
;
eval
$q4
;
eval
explain
extended
$q4
;
eval
prepare
stmt
from
"
$q4
"
;
execute
stmt
;
execute
stmt
;
drop
procedure
p
;
drop
table
t2
;
create
table
t2
(
c1
int
,
c2
int
);
eval
create
procedure
p
()
insert
into
t2
$q4
;
call
p
();
select
*
from
t2
;
drop
procedure
p
;
drop
procedure
p
;
drop
table
t1
,
t2
;
drop
table
t1
,
t2
;
...
@@ -2609,7 +2633,51 @@ eval analyze format=json $q;
...
@@ -2609,7 +2633,51 @@ eval analyze format=json $q;
drop
function
f1
;
drop
function
f1
;
drop
table
t1
,
t2
;
drop
table
t1
,
t2
;
--
echo
End
of
10.2
tests
--
echo
#
--
echo
# MDEV-22748: two materialized CTEs using the same recursive CTE
--
echo
# (see also test case for MDEV-17024)
--
echo
#
CREATE
TABLE
t1
(
YEAR
int
(
4
),
d1
date
,
d2
date
)
;
INSERT
INTO
t1
VALUES
(
2018
,
'2018-01-01'
,
'2018-09-20'
);
CREATE
TABLE
t2
(
id
int
,
tm
date
);
INSERT
INTO
t2
VALUES
(
1
,
'2018-08-30'
),(
2
,
'2018-08-30'
),(
3
,
'2018-08-30'
);
CREATE
TABLE
t3
(
id
int
,
tm
date
);
INSERT
INTO
t3
VALUES
(
1
,
'2018-08-30'
),(
2
,
'2018-08-30'
);
let
$q
=
WITH
RECURSIVE
cte
AS
(
SELECT
YEAR
(
t1
.
d1
)
AS
YEAR
,
t1
.
d1
AS
st
,
t1
.
d1
+
INTERVAL
1
MONTH
AS
fn
FROM
t1
UNION
ALL
SELECT
YEAR
(
cte
.
st
+
INTERVAL
1
MONTH
),
cte
.
st
+
INTERVAL
1
MONTH
,
t1
.
d2
+
INTERVAL
1
DAY
FROM
cte
JOIN
t1
WHERE
cte
.
st
+
INTERVAL
1
MONTH
<
t1
.
d2
),
cte2
AS
(
SELECT
YEAR
,
COUNT
(
*
)
FROM
cte
JOIN
t2
ON
t2
.
tm
BETWEEN
cte
.
st
AND
cte
.
fn
),
cte3
AS
(
SELECT
YEAR
,
COUNT
(
*
)
FROM
cte
JOIN
t3
ON
t3
.
tm
BETWEEN
cte
.
st
AND
cte
.
fn
)
SELECT
t1
.*
FROM
t1
JOIN
cte2
USING
(
YEAR
)
JOIN
cte3
USING
(
YEAR
);
eval
$q
;
eval
EXPLAIN
EXTENDED
$q
;
eval
PREPARE
stmt
FROM
"
$q
"
;
EXECUTE
stmt
;
EXECUTE
stmt
;
CREATE
TABLE
t4
(
YEAR
int
(
4
),
d1
date
,
d2
date
);
eval
CREATE
PROCEDURE
p
()
INSERT
INTO
t4
$q
;
CALL
p
();
SELECT
*
FROM
t4
;
DROP
PROCEDURE
p
;
DROP
TABLE
t1
,
t2
,
t3
,
t4
;
--
echo
#
--
echo
# End of 10.2 tests
--
echo
#
--
echo
#
--
echo
#
--
echo
# MDEV-14217 [db crash] Recursive CTE when SELECT includes new field
--
echo
# MDEV-14217 [db crash] Recursive CTE when SELECT includes new field
...
...
sql/sql_cte.cc
View file @
befb0bed
...
@@ -1114,6 +1114,7 @@ bool TABLE_LIST::set_as_with_table(THD *thd, With_element *with_elem)
...
@@ -1114,6 +1114,7 @@ bool TABLE_LIST::set_as_with_table(THD *thd, With_element *with_elem)
{
{
derived
=
with_elem
->
spec
;
derived
=
with_elem
->
spec
;
if
(
derived
!=
select_lex
->
master_unit
()
&&
if
(
derived
!=
select_lex
->
master_unit
()
&&
!
with_elem
->
is_recursive
&&
!
is_with_table_recursive_reference
())
!
is_with_table_recursive_reference
())
{
{
derived
->
move_as_slave
(
select_lex
);
derived
->
move_as_slave
(
select_lex
);
...
...
sql/sql_derived.cc
View file @
befb0bed
/*
/*
Copyright (c) 2002, 2011, Oracle and/or its affiliates.
Copyright (c) 2002, 2011, Oracle and/or its affiliates.
Copyright (c) 2010, 20
15
, MariaDB
Copyright (c) 2010, 20
20
, MariaDB
This program is free software; you can redistribute it and/or modify
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
it under the terms of the GNU General Public License as published by
...
@@ -1110,7 +1110,6 @@ bool mysql_derived_fill(THD *thd, LEX *lex, TABLE_LIST *derived)
...
@@ -1110,7 +1110,6 @@ bool mysql_derived_fill(THD *thd, LEX *lex, TABLE_LIST *derived)
DBUG_ASSERT
(
derived
->
table
&&
derived
->
table
->
is_created
());
DBUG_ASSERT
(
derived
->
table
&&
derived
->
table
->
is_created
());
select_unit
*
derived_result
=
derived
->
derived_result
;
select_unit
*
derived_result
=
derived
->
derived_result
;
SELECT_LEX
*
save_current_select
=
lex
->
current_select
;
SELECT_LEX
*
save_current_select
=
lex
->
current_select
;
bool
derived_recursive_is_filled
=
false
;
if
(
unit
->
executed
&&
!
derived_is_recursive
&&
if
(
unit
->
executed
&&
!
derived_is_recursive
&&
(
unit
->
uncacheable
&
UNCACHEABLE_DEPENDENT
))
(
unit
->
uncacheable
&
UNCACHEABLE_DEPENDENT
))
...
@@ -1139,7 +1138,6 @@ bool mysql_derived_fill(THD *thd, LEX *lex, TABLE_LIST *derived)
...
@@ -1139,7 +1138,6 @@ bool mysql_derived_fill(THD *thd, LEX *lex, TABLE_LIST *derived)
{
{
/* In this case all iteration are performed */
/* In this case all iteration are performed */
res
=
derived
->
fill_recursive
(
thd
);
res
=
derived
->
fill_recursive
(
thd
);
derived_recursive_is_filled
=
true
;
}
}
}
}
else
if
(
unit
->
is_unit_op
())
else
if
(
unit
->
is_unit_op
())
...
@@ -1195,8 +1193,7 @@ bool mysql_derived_fill(THD *thd, LEX *lex, TABLE_LIST *derived)
...
@@ -1195,8 +1193,7 @@ bool mysql_derived_fill(THD *thd, LEX *lex, TABLE_LIST *derived)
}
}
}
}
err:
err:
if
(
res
||
(
!
lex
->
describe
&&
!
unit
->
uncacheable
&&
if
(
res
||
(
!
derived_is_recursive
&&
!
lex
->
describe
&&
!
unit
->
uncacheable
))
(
!
derived_is_recursive
||
derived_recursive_is_filled
)))
unit
->
cleanup
();
unit
->
cleanup
();
lex
->
current_select
=
save_current_select
;
lex
->
current_select
=
save_current_select
;
...
...
sql/sql_union.cc
View file @
befb0bed
...
@@ -2030,6 +2030,19 @@ bool st_select_lex::cleanup()
...
@@ -2030,6 +2030,19 @@ bool st_select_lex::cleanup()
delete
join
;
delete
join
;
join
=
0
;
join
=
0
;
}
}
for
(
TABLE_LIST
*
tbl
=
get_table_list
();
tbl
;
tbl
=
tbl
->
next_local
)
{
if
(
tbl
->
is_recursive_with_table
()
&&
!
tbl
->
is_with_table_recursive_reference
())
{
/*
If query is killed before open_and_process_table() for tbl
is called then 'with' is already set, but 'derived' is not.
*/
st_select_lex_unit
*
unit
=
tbl
->
with
->
spec
;
error
|=
(
bool
)
error
|
(
uint
)
unit
->
cleanup
();
}
}
for
(
SELECT_LEX_UNIT
*
lex_unit
=
first_inner_unit
();
lex_unit
;
for
(
SELECT_LEX_UNIT
*
lex_unit
=
first_inner_unit
();
lex_unit
;
lex_unit
=
lex_unit
->
next_unit
())
lex_unit
=
lex_unit
->
next_unit
())
{
{
...
...
storage/innobase/srv/srv0srv.cc
View file @
befb0bed
...
@@ -2678,7 +2678,7 @@ srv_purge_coordinator_suspend(
...
@@ -2678,7 +2678,7 @@ srv_purge_coordinator_suspend(
rw_lock_x_lock
(
&
purge_sys
.
latch
);
rw_lock_x_lock
(
&
purge_sys
.
latch
);
stop
=
srv_shutdown_state
==
SRV_SHUTDOWN_NONE
stop
=
srv_shutdown_state
<=
SRV_SHUTDOWN_INITIATED
&&
purge_sys
.
paused_latched
();
&&
purge_sys
.
paused_latched
();
if
(
!
stop
)
{
if
(
!
stop
)
{
...
@@ -2743,7 +2743,7 @@ DECLARE_THREAD(srv_purge_coordinator_thread)(
...
@@ -2743,7 +2743,7 @@ DECLARE_THREAD(srv_purge_coordinator_thread)(
/* If there are no records to purge or the last
/* If there are no records to purge or the last
purge didn't purge any records then wait for activity. */
purge didn't purge any records then wait for activity. */
if
(
srv_shutdown_state
==
SRV_SHUTDOWN_NONE
if
(
srv_shutdown_state
<=
SRV_SHUTDOWN_INITIATED
&&
srv_undo_sources
&&
srv_undo_sources
&&
(
n_total_purged
==
0
||
purge_sys
.
paused
()))
{
&&
(
n_total_purged
==
0
||
purge_sys
.
paused
()))
{
...
...
storage/innobase/srv/srv0start.cc
View file @
befb0bed
...
@@ -3,7 +3,7 @@
...
@@ -3,7 +3,7 @@
Copyright (c) 1996, 2017, Oracle and/or its affiliates. All rights reserved.
Copyright (c) 1996, 2017, Oracle and/or its affiliates. All rights reserved.
Copyright (c) 2008, Google Inc.
Copyright (c) 2008, Google Inc.
Copyright (c) 2009, Percona Inc.
Copyright (c) 2009, Percona Inc.
Copyright (c) 2013, 20
19
, MariaDB Corporation.
Copyright (c) 2013, 20
20
, MariaDB Corporation.
Portions of this file contain modifications contributed and copyrighted by
Portions of this file contain modifications contributed and copyrighted by
Google, Inc. Those modifications are gratefully acknowledged and are described
Google, Inc. Those modifications are gratefully acknowledged and are described
...
@@ -2426,7 +2426,7 @@ dberr_t srv_start(bool create_new_db)
...
@@ -2426,7 +2426,7 @@ dberr_t srv_start(bool create_new_db)
thread_started
[
5
+
i
+
SRV_MAX_N_IO_THREADS
]
=
true
;
thread_started
[
5
+
i
+
SRV_MAX_N_IO_THREADS
]
=
true
;
}
}
while
(
srv_shutdown_state
==
SRV_SHUTDOWN_NONE
while
(
srv_shutdown_state
<=
SRV_SHUTDOWN_INITIATED
&&
srv_force_recovery
<
SRV_FORCE_NO_BACKGROUND
&&
srv_force_recovery
<
SRV_FORCE_NO_BACKGROUND
&&
!
purge_sys
.
enabled
())
{
&&
!
purge_sys
.
enabled
())
{
ib
::
info
()
<<
"Waiting for purge to start"
;
ib
::
info
()
<<
"Waiting for purge to start"
;
...
...
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