Files
greptimedb/tests/cases/standalone/common/subquery/neumann.result
dennis zhuang 24e5c9f6da test: migrate duckdb tests, part 1 (#6870)
* test: migrate duckdb tests

Signed-off-by: Dennis Zhuang <killme2008@gmail.com>

* fix: style

Signed-off-by: Dennis Zhuang <killme2008@gmail.com>

* test: add more duckdb tests

Signed-off-by: Dennis Zhuang <killme2008@gmail.com>

* fix: stable order

Signed-off-by: Dennis Zhuang <killme2008@gmail.com>

* chore: simplfy comments

Signed-off-by: Dennis Zhuang <killme2008@gmail.com>

* chore: remove tests/cases/standalone/common/DUCKDB_MIGRATION_GUIDE.md

* fix: incorrect_sql.sql

Signed-off-by: Dennis Zhuang <killme2008@gmail.com>

* fix: integer flow test

Signed-off-by: Dennis Zhuang <killme2008@gmail.com>

* fix: integer flow test

Signed-off-by: Dennis Zhuang <killme2008@gmail.com>

* docs: add todo

Signed-off-by: Dennis Zhuang <killme2008@gmail.com>

---------

Signed-off-by: Dennis Zhuang <killme2008@gmail.com>
2025-09-05 06:10:14 +00:00

82 lines
2.3 KiB
Plaintext

-- Migrated from DuckDB test: test/sql/subquery/test_neumann.test
-- Description: Test subqueries from the paper 'Unnesting Arbitrary Subqueries'
CREATE TABLE students("id" INTEGER, "name" VARCHAR, major VARCHAR, "year" INTEGER, ts TIMESTAMP TIME INDEX);
Affected Rows: 0
CREATE TABLE exams(sid INTEGER, course VARCHAR, curriculum VARCHAR, grade INTEGER, "year" INTEGER, ts TIMESTAMP TIME INDEX);
Affected Rows: 0
INSERT INTO students VALUES (1, 'Mark', 'CS', 2017, 1000);
Affected Rows: 1
INSERT INTO students VALUES (2, 'Dirk', 'CS', 2017, 2000);
Affected Rows: 1
INSERT INTO exams VALUES (1, 'Database Systems', 'CS', 10, 2015, 3000);
Affected Rows: 1
INSERT INTO exams VALUES (1, 'Graphics', 'CS', 9, 2016, 4000);
Affected Rows: 1
INSERT INTO exams VALUES (2, 'Database Systems', 'CS', 7, 2015, 5000);
Affected Rows: 1
INSERT INTO exams VALUES (2, 'Graphics', 'CS', 7, 2016, 6000);
Affected Rows: 1
-- Test 1: Subquery with MAX aggregation
SELECT s."name", e.course, e.grade
FROM students s, exams e
WHERE s."id"=e.sid AND e.grade=(SELECT MAX(e2.grade) FROM exams e2 WHERE s."id"=e2.sid)
ORDER BY "name", course;
+------+------------------+-------+
| name | course | grade |
+------+------------------+-------+
| Dirk | Database Systems | 7 |
| Dirk | Graphics | 7 |
| Mark | Database Systems | 10 |
+------+------------------+-------+
-- Test 2: Complex subquery with AVG and conditions
-- TODO: It raise an error right now: Physical plan does not support logical expression ScalarSubquery(<subquery>)
SELECT s."name", e.course, e.grade
FROM students s, exams e
WHERE s."id"=e.sid
AND (s.major = 'CS' OR s.major = 'Games Eng')
AND e.grade <= (SELECT AVG(e2.grade) - 1 FROM exams e2 WHERE s."id"=e2.sid OR (e2.curriculum=s.major AND s."year">=e2."year"))
ORDER BY "name", course;
Error: 1001(Unsupported), This feature is not implemented: Physical plan does not support logical expression ScalarSubquery(<subquery>)
-- Test 3: EXISTS subquery
SELECT "name", major
FROM students s
WHERE EXISTS(SELECT * FROM exams e WHERE e.sid=s."id" AND grade=10) OR s."name"='Dirk'
ORDER BY "name";
+------+-------+
| name | major |
+------+-------+
| Dirk | CS |
| Mark | CS |
+------+-------+
-- Clean up
DROP TABLE exams;
Affected Rows: 0
DROP TABLE students;
Affected Rows: 0