Commit 17fc288b authored by Sergei Petrunia's avatar Sergei Petrunia

MDEV-13352: Server crashes in st_join_table::remove_duplicates

Do not run the window function computation step when the select
produces no rows (zero_result_cause!=NULL).
This may cause reads from uninitialized memory.

We still need to run the window function computation step when
the output includes just one row  (for example
SELECT MAX(col), RANK() OVER (...) FROM t1 WHERE 1=0).

This fix also resolves an issue with queries with window functions
producing an output row where should be none, like in
SELECT ROW_NUMBER() FROM t1 WHERE 1=0.

Updated a few test results in the existing tests to reflect this.
parent bc75c57c
...@@ -2762,10 +2762,8 @@ CREATE TABLE t1 (i INT); ...@@ -2762,10 +2762,8 @@ CREATE TABLE t1 (i INT);
INSERT INTO t1 VALUES (3), (1), (2); INSERT INTO t1 VALUES (3), (1), (2);
SELECT i, ROW_NUMBER() OVER () FROM t1 WHERE 1 = 2; SELECT i, ROW_NUMBER() OVER () FROM t1 WHERE 1 = 2;
i ROW_NUMBER() OVER () i ROW_NUMBER() OVER ()
NULL 1
SELECT i, COUNT(*) OVER () FROM t1 WHERE 1 = 2; SELECT i, COUNT(*) OVER () FROM t1 WHERE 1 = 2;
i COUNT(*) OVER () i COUNT(*) OVER ()
NULL 1
DROP TABLE t1; DROP TABLE t1;
# #
# MDEV-12051: window function in query with implicit grouping # MDEV-12051: window function in query with implicit grouping
...@@ -3141,3 +3139,13 @@ sum(i) over (order by i) interval(sum(i) over (order by i), 10, 20) ...@@ -3141,3 +3139,13 @@ sum(i) over (order by i) interval(sum(i) over (order by i), 10, 20)
33 2 33 2
63 2 63 2
drop table t1; drop table t1;
#
# MDEV-13352: Server crashes in st_join_table::remove_duplicates
#
CREATE TABLE t1 (i INT);
INSERT INTO t1 VALUES (1),(2);
SELECT DISTINCT ROW_NUMBER() OVER(), i FROM t1 WHERE 0;
ROW_NUMBER() OVER() i
SELECT ROW_NUMBER() OVER(), i FROM t1 WHERE 0;
ROW_NUMBER() OVER() i
DROP TABLE t1;
...@@ -11,10 +11,6 @@ c1 c2 ...@@ -11,10 +11,6 @@ c1 c2
4 manual_insert_2 4 manual_insert_2
11 should repeat 4 times [11-14] 11 should repeat 4 times [11-14]
12 should repeat 4 times [11-14] 12 should repeat 4 times [11-14]
13 should repeat 4 times [11-14]
14 should repeat 4 times [11-14]
0 should_have_0
2 should_have_2
DELETE FROM t1; DELETE FROM t1;
EXECUTE populate_table; EXECUTE populate_table;
INSERT INTO t1 INSERT INTO t1
......
...@@ -1923,3 +1923,14 @@ insert into t1 values (1),(2),(10),(20),(30); ...@@ -1923,3 +1923,14 @@ insert into t1 values (1),(2),(10),(20),(30);
select sum(i) over (order by i), interval(sum(i) over (order by i), 10, 20) select sum(i) over (order by i), interval(sum(i) over (order by i), 10, 20)
from t1; from t1;
drop table t1; drop table t1;
--echo #
--echo # MDEV-13352: Server crashes in st_join_table::remove_duplicates
--echo #
CREATE TABLE t1 (i INT);
INSERT INTO t1 VALUES (1),(2);
SELECT DISTINCT ROW_NUMBER() OVER(), i FROM t1 WHERE 0;
SELECT ROW_NUMBER() OVER(), i FROM t1 WHERE 0;
DROP TABLE t1;
...@@ -3398,8 +3398,14 @@ void JOIN::exec_inner() ...@@ -3398,8 +3398,14 @@ void JOIN::exec_inner()
if (zero_result_cause) if (zero_result_cause)
{ {
if (select_lex->have_window_funcs()) if (select_lex->have_window_funcs() && send_row_on_empty_set())
{ {
/*
The query produces just one row but it has window functions.
The only way to compute the value of window function(s) is to
run the entire window function computation step (there is no shortcut).
*/
const_tables= table_count; const_tables= table_count;
first_select= sub_select_postjoin_aggr; first_select= sub_select_postjoin_aggr;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment