From 814924a7872a68ee265bce5e4946f72925417f00 Mon Sep 17 00:00:00 2001 From: Vitor Mattos Date: Fri, 17 Dec 2021 17:21:35 -0300 Subject: Accept multipe args on concat Signed-off-by: Vitor Mattos --- lib/private/DB/QueryBuilder/FunctionBuilder/FunctionBuilder.php | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) (limited to 'lib/private/DB/QueryBuilder/FunctionBuilder/FunctionBuilder.php') diff --git a/lib/private/DB/QueryBuilder/FunctionBuilder/FunctionBuilder.php b/lib/private/DB/QueryBuilder/FunctionBuilder/FunctionBuilder.php index 37518bda3ec..03630ea14a3 100644 --- a/lib/private/DB/QueryBuilder/FunctionBuilder/FunctionBuilder.php +++ b/lib/private/DB/QueryBuilder/FunctionBuilder/FunctionBuilder.php @@ -50,8 +50,13 @@ class FunctionBuilder implements IFunctionBuilder { return new QueryFunction('MD5(' . $this->helper->quoteColumnName($input) . ')'); } - public function concat($x, $y): IQueryFunction { - return new QueryFunction('CONCAT(' . $this->helper->quoteColumnName($x) . ', ' . $this->helper->quoteColumnName($y) . ')'); + public function concat($x, ...$expr): IQueryFunction { + $args = func_get_args(); + $list = []; + foreach ($args as $item) { + $list[] = $this->helper->quoteColumnName($item); + } + return new QueryFunction(sprintf('CONCAT(%s)', implode(', ', $list))); } public function groupConcat($expr, ?string $separator = ','): IQueryFunction { -- cgit v1.2.3