Files
greptimedb/tests/cases/standalone/common/join/join_with_subqueries.result
dennis zhuang 6c066c1a4a test: migrate join tests from duckdb, part3 (#6881)
* test: migrate join tests

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

* chore: update test results after rebasing main branch

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

* fix: unstable query sort results and natural_join test

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

* fix: count(*) with joining

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

* fix: unstable query sort results and style

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

---------

Signed-off-by: Dennis Zhuang <killme2008@gmail.com>
2025-09-12 04:20:00 +00:00

156 lines
4.8 KiB
Plaintext

-- Migrated from DuckDB test: test/sql/join/ subquery join tests
-- Tests joins involving subqueries
CREATE TABLE products_sub(prod_id INTEGER, prod_name VARCHAR, category_id INTEGER, price DOUBLE, ts TIMESTAMP TIME INDEX);
Affected Rows: 0
CREATE TABLE categories_sub(cat_id INTEGER, cat_name VARCHAR, ts TIMESTAMP TIME INDEX);
Affected Rows: 0
CREATE TABLE sales_sub(sale_id INTEGER, prod_id INTEGER, quantity INTEGER, sale_date DATE, ts TIMESTAMP TIME INDEX);
Affected Rows: 0
INSERT INTO products_sub VALUES
(1, 'Laptop', 1, 1200.00, 1000), (2, 'Mouse', 2, 25.00, 2000),
(3, 'Monitor', 1, 400.00, 3000), (4, 'Keyboard', 2, 80.00, 4000),
(5, 'Tablet', 1, 600.00, 5000);
Affected Rows: 5
INSERT INTO categories_sub VALUES
(1, 'Electronics', 1000), (2, 'Accessories', 2000);
Affected Rows: 2
INSERT INTO sales_sub VALUES
(1, 1, 2, '2023-01-01', 1000), (2, 2, 10, '2023-01-02', 2000),
(3, 3, 1, '2023-01-03', 3000), (4, 1, 1, '2023-01-04', 4000),
(5, 4, 5, '2023-01-05', 5000), (6, 5, 2, '2023-01-06', 6000);
Affected Rows: 6
-- Join with aggregated subquery
SELECT
p.prod_name, p.price, sales_summary.total_quantity, sales_summary.total_sales
FROM products_sub p
INNER JOIN (
SELECT prod_id, SUM(quantity) as total_quantity, COUNT(*) as total_sales
FROM sales_sub
GROUP BY prod_id
) sales_summary ON p.prod_id = sales_summary.prod_id
ORDER BY sales_summary.total_quantity DESC;
+-----------+--------+----------------+-------------+
| prod_name | price | total_quantity | total_sales |
+-----------+--------+----------------+-------------+
| Mouse | 25.0 | 10 | 1 |
| Keyboard | 80.0 | 5 | 1 |
| Laptop | 1200.0 | 3 | 2 |
| Tablet | 600.0 | 2 | 1 |
| Monitor | 400.0 | 1 | 1 |
+-----------+--------+----------------+-------------+
-- Join with filtered subquery
SELECT
p.prod_name, c.cat_name, high_sales.quantity
FROM products_sub p
INNER JOIN categories_sub c ON p.category_id = c.cat_id
INNER JOIN (
SELECT prod_id, quantity
FROM sales_sub
WHERE quantity > 3
) high_sales ON p.prod_id = high_sales.prod_id
ORDER BY high_sales.quantity DESC;
+-----------+-------------+----------+
| prod_name | cat_name | quantity |
+-----------+-------------+----------+
| Mouse | Accessories | 10 |
| Keyboard | Accessories | 5 |
+-----------+-------------+----------+
-- Join with correlated subquery results
SELECT
p.prod_name, p.price,
(SELECT SUM(s.quantity) FROM sales_sub s WHERE s.prod_id = p.prod_id) as total_sold
FROM products_sub p
WHERE EXISTS (SELECT 1 FROM sales_sub s WHERE s.prod_id = p.prod_id)
ORDER BY total_sold DESC;
+-----------+--------+------------+
| prod_name | price | total_sold |
+-----------+--------+------------+
| Mouse | 25.0 | 10 |
| Keyboard | 80.0 | 5 |
| Laptop | 1200.0 | 3 |
| Tablet | 600.0 | 2 |
| Monitor | 400.0 | 1 |
+-----------+--------+------------+
-- Join subquery with window functions
SELECT
p.prod_name, ranked_sales.quantity, ranked_sales.sale_rank
FROM products_sub p
INNER JOIN (
SELECT
prod_id, quantity,
ROW_NUMBER() OVER (PARTITION BY prod_id ORDER BY quantity DESC) as sale_rank
FROM sales_sub
) ranked_sales ON p.prod_id = ranked_sales.prod_id
WHERE ranked_sales.sale_rank = 1
ORDER BY ranked_sales.quantity DESC, p.prod_name ASC;
+-----------+----------+-----------+
| prod_name | quantity | sale_rank |
+-----------+----------+-----------+
| Mouse | 10 | 1 |
| Keyboard | 5 | 1 |
| Laptop | 2 | 1 |
| Tablet | 2 | 1 |
| Monitor | 1 | 1 |
+-----------+----------+-----------+
-- Multiple subquery joins
SELECT
product_stats.prod_name,
product_stats.avg_price,
category_stats.category_sales
FROM (
SELECT prod_id, prod_name, AVG(price) as avg_price, category_id
FROM products_sub
GROUP BY prod_id, prod_name, category_id
) product_stats
INNER JOIN (
SELECT c.cat_id, c.cat_name, COUNT(s.sale_id) as category_sales
FROM categories_sub c
INNER JOIN products_sub p ON c.cat_id = p.category_id
INNER JOIN sales_sub s ON p.prod_id = s.prod_id
GROUP BY c.cat_id, c.cat_name
) category_stats ON product_stats.category_id = category_stats.cat_id
ORDER BY category_stats.category_sales DESC, product_stats.prod_name DESC;
+-----------+-----------+----------------+
| prod_name | avg_price | category_sales |
+-----------+-----------+----------------+
| Tablet | 600.0 | 4 |
| Monitor | 400.0 | 4 |
| Laptop | 1200.0 | 4 |
| Mouse | 25.0 | 2 |
| Keyboard | 80.0 | 2 |
+-----------+-----------+----------------+
DROP TABLE products_sub;
Affected Rows: 0
DROP TABLE categories_sub;
Affected Rows: 0
DROP TABLE sales_sub;
Affected Rows: 0