From 3f2cb3d364851e54080277499a9a7c150364538d Mon Sep 17 00:00:00 2001 From: Zachary Lund Date: Fri, 12 Jul 2024 13:53:29 -0500 Subject: [PATCH] Fix subselect aggregate functions --- .../QueryAggregateFunctionDetectorTreeWalker.php | 4 ++++ .../QueryResultTypeWalkerFetchTypeMatrixTest.php | 16 ++++++++++++++++ 2 files changed, 20 insertions(+) diff --git a/src/Type/Doctrine/Query/QueryAggregateFunctionDetectorTreeWalker.php b/src/Type/Doctrine/Query/QueryAggregateFunctionDetectorTreeWalker.php index c82527a3..7e891222 100644 --- a/src/Type/Doctrine/Query/QueryAggregateFunctionDetectorTreeWalker.php +++ b/src/Type/Doctrine/Query/QueryAggregateFunctionDetectorTreeWalker.php @@ -25,6 +25,10 @@ public function walkNode($node): void return; } + if ($node instanceof AST\Subselect) { + return; + } + if ($this->isAggregateFunction($node)) { $this->markAggregateFunctionFound(); return; diff --git a/tests/Platform/QueryResultTypeWalkerFetchTypeMatrixTest.php b/tests/Platform/QueryResultTypeWalkerFetchTypeMatrixTest.php index 4df903c0..04fdcba8 100644 --- a/tests/Platform/QueryResultTypeWalkerFetchTypeMatrixTest.php +++ b/tests/Platform/QueryResultTypeWalkerFetchTypeMatrixTest.php @@ -3833,6 +3833,22 @@ public static function provideCases(): iterable 'stringify' => self::STRINGIFY_NONE, ]; + yield 'SUBSELECT' => [ + 'data' => self::dataDefault(), + 'select' => 'SELECT t1.col_int, (SELECT COUNT(t2.col_int) FROM ' . PlatformEntity::class . ' t2) FROM %s t1', + 'mysql' => self::int(), + 'sqlite' => self::int(), + 'pdo_pgsql' => self::int(), + 'pgsql' => self::int(), + 'mssql' => self::int(), + 'mysqlResult' => 9, + 'sqliteResult' => 9, + 'pdoPgsqlResult' => 9, + 'pgsqlResult' => 9, + 'mssqlResult' => 9, + 'stringify' => self::STRINGIFY_NONE, + ]; + yield 'COUNT(t.col_int)' => [ 'data' => self::dataDefault(), 'select' => 'SELECT COUNT(t.col_int) FROM %s t',