Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -307,7 +307,8 @@ class Analyzer(

val attrLength = groupByAliases.length
val expandedAttributes = groupByAliases.zipWithIndex.map { case (a, idx) =>
a.toAttribute.withNullability(((nullBitmask >> (attrLength - idx - 1)) & 1) == 1)
val canBeNull = ((nullBitmask >> (attrLength - idx - 1)) & 1) == 1
a.toAttribute.withNullability(a.nullable || canBeNull)
}

val expand = Expand(x.bitmasks, groupByAliases, expandedAttributes, gid, x.child)
Expand Down
12 changes: 10 additions & 2 deletions sql/core/src/test/resources/sql-tests/inputs/grouping_set.sql
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,12 @@ CREATE TEMPORARY VIEW grouping AS SELECT * FROM VALUES
("1", "2", "3", 1),
("4", "5", "6", 1),
("7", "8", "9", 1)
as grouping(a, b, c, d);
AS grouping(a, b, c, d);

CREATE TEMPORARY VIEW grouping_null AS SELECT * FROM VALUES
CAST(NULL AS STRING),
CAST(NULL AS STRING)
AS T(e);

-- SPARK-17849: grouping set throws NPE #1
SELECT a, b, c, count(d) FROM grouping GROUP BY a, b, c GROUPING SETS (());
Expand All @@ -13,5 +18,8 @@ SELECT a, b, c, count(d) FROM grouping GROUP BY a, b, c GROUPING SETS ((a));
-- SPARK-17849: grouping set throws NPE #3
SELECT a, b, c, count(d) FROM grouping GROUP BY a, b, c GROUPING SETS ((c));

-- SPARK-19509: grouping set should honor input nullability
SELECT COUNT(1) FROM grouping_null GROUP BY e GROUPING SETS (e);


DROP VIEW IF EXISTS grouping;
DROP VIEW IF EXISTS grouping_null;
53 changes: 44 additions & 9 deletions sql/core/src/test/resources/sql-tests/results/grouping_set.sql.out
Original file line number Diff line number Diff line change
@@ -1,42 +1,77 @@
-- Automatically generated by SQLQueryTestSuite
-- Number of queries: 4
-- Number of queries: 8


-- !query 0
CREATE TEMPORARY VIEW grouping AS SELECT * FROM VALUES
("1", "2", "3", 1),
("4", "5", "6", 1),
("7", "8", "9", 1)
as grouping(a, b, c, d)
AS grouping(a, b, c, d)
-- !query 0 schema
struct<>
-- !query 0 output



-- !query 1
SELECT a, b, c, count(d) FROM grouping GROUP BY a, b, c GROUPING SETS (())
CREATE TEMPORARY VIEW grouping_null AS SELECT * FROM VALUES
CAST(NULL AS STRING),
CAST(NULL AS STRING)
AS T(e)
-- !query 1 schema
struct<a:string,b:string,c:string,count(d):bigint>
struct<>
-- !query 1 output
NULL NULL NULL 3



-- !query 2
SELECT a, b, c, count(d) FROM grouping GROUP BY a, b, c GROUPING SETS ((a))
SELECT a, b, c, count(d) FROM grouping GROUP BY a, b, c GROUPING SETS (())
-- !query 2 schema
struct<a:string,b:string,c:string,count(d):bigint>
-- !query 2 output
NULL NULL NULL 3


-- !query 3
SELECT a, b, c, count(d) FROM grouping GROUP BY a, b, c GROUPING SETS ((a))
-- !query 3 schema
struct<a:string,b:string,c:string,count(d):bigint>
-- !query 3 output
1 NULL NULL 1
4 NULL NULL 1
7 NULL NULL 1


-- !query 3
-- !query 4
SELECT a, b, c, count(d) FROM grouping GROUP BY a, b, c GROUPING SETS ((c))
-- !query 3 schema
-- !query 4 schema
struct<a:string,b:string,c:string,count(d):bigint>
-- !query 3 output
-- !query 4 output
NULL NULL 3 1
NULL NULL 6 1
NULL NULL 9 1


-- !query 5
SELECT COUNT(1) FROM grouping_null GROUP BY e GROUPING SETS (e)
-- !query 5 schema
struct<count(1):bigint>
-- !query 5 output
2


-- !query 6
DROP VIEW IF EXISTS grouping
-- !query 6 schema
struct<>
-- !query 6 output



-- !query 7
DROP VIEW IF EXISTS grouping_null
-- !query 7 schema
struct<>
-- !query 7 output