Files
greptimedb/tests/cases/standalone/common/aggregate/avg.result
LFC b2074e3863 chore: upgrade DataFusion family, again (#7578)
* chore: upgrade DataFusion family

Signed-off-by: luofucong <luofc@foxmail.com>

* chore: switch to released version of datafusion-pg-catalog

---------

Signed-off-by: luofucong <luofc@foxmail.com>
Co-authored-by: Ning Sun <sunning@greptime.com>
Co-authored-by: Ning Sun <sunng@protonmail.com>
2026-03-03 07:36:39 +00:00

101 lines
2.2 KiB
Plaintext

-- Migrated from DuckDB test: test/sql/aggregate/aggregates/test_avg.test
-- Test AVG aggregate function
-- scalar average
SELECT AVG(3);
+---------------+
| avg(Int64(3)) |
+---------------+
| 3.0 |
+---------------+
-- FIXME(dennis): unsupported type
-- SELECT AVG(NULL);
SELECT AVG(3::SMALLINT), AVG(NULL::SMALLINT);
+---------------+-----------+
| avg(Int64(3)) | avg(NULL) |
+---------------+-----------+
| 3.0 | |
+---------------+-----------+
SELECT AVG(3::DOUBLE), AVG(NULL::DOUBLE);
+---------------+-----------+
| avg(Int64(3)) | avg(NULL) |
+---------------+-----------+
| 3.0 | |
+---------------+-----------+
-- test average with table
CREATE TABLE integers(i INTEGER, ts TIMESTAMP TIME INDEX);
Affected Rows: 0
INSERT INTO integers VALUES (1, 1000), (2, 2000), (3, 3000);
Affected Rows: 3
SELECT AVG(i), AVG(1), AVG(DISTINCT i), AVG(NULL) FROM integers;
Error: 3001(EngineExecuteQuery), Execution error: AvgAccumulator for (Null --> Float64)
SELECT AVG(i) FROM integers WHERE i > 100;
+-----------------+
| avg(integers.i) |
+-----------------+
| |
+-----------------+
-- empty average
CREATE TABLE vals(i INTEGER, j DOUBLE, k BIGINT, ts TIMESTAMP TIME INDEX);
Affected Rows: 0
INSERT INTO vals VALUES (NULL, NULL, NULL, 1000);
Affected Rows: 1
SELECT AVG(i), AVG(j), AVG(k) FROM vals;
+-------------+-------------+-------------+
| avg(vals.i) | avg(vals.j) | avg(vals.k) |
+-------------+-------------+-------------+
| | | |
+-------------+-------------+-------------+
-- test with mixed values
DROP TABLE vals;
Affected Rows: 0
CREATE TABLE vals(i INTEGER, j DOUBLE, ts TIMESTAMP TIME INDEX);
Affected Rows: 0
INSERT INTO vals VALUES (1, 1.5, 1000), (2, 2.5, 2000), (3, 3.5, 3000), (NULL, NULL, 4000);
Affected Rows: 4
SELECT AVG(i), AVG(j) FROM vals;
+-------------+-------------+
| avg(vals.i) | avg(vals.j) |
+-------------+-------------+
| 2.0 | 2.5 |
+-------------+-------------+
-- FIXME(dennis): AVG(DISTINCT) not supported
-- https://github.com/apache/datafusion/issues/2408
-- SELECT AVG(DISTINCT i), AVG(DISTINCT j) FROM vals;
-- cleanup
DROP TABLE integers;
Affected Rows: 0
DROP TABLE vals;
Affected Rows: 0