diff options
author | Vincent Petry <vincent@nextcloud.com> | 2022-06-13 11:55:37 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-06-13 11:55:37 +0200 |
commit | 8809de1eefbfa78998d9379a7040858d8e01e820 (patch) | |
tree | 4e58c2153749cb486472efc8bcc220318c0f50a0 /lib/private/DB/QueryBuilder/FunctionBuilder | |
parent | c26ddf10de489fe86be6232d9d409b3acb930cec (diff) | |
parent | 8238582e59b7b6ec03318bcf81bf47cce54af320 (diff) | |
download | nextcloud-server-8809de1eefbfa78998d9379a7040858d8e01e820.tar.gz nextcloud-server-8809de1eefbfa78998d9379a7040858d8e01e820.zip |
Merge pull request #31966 from nextcloud/unencrypted-size
store unencrypted size in the unencrypted_size column
Diffstat (limited to 'lib/private/DB/QueryBuilder/FunctionBuilder')
-rw-r--r-- | lib/private/DB/QueryBuilder/FunctionBuilder/FunctionBuilder.php | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/lib/private/DB/QueryBuilder/FunctionBuilder/FunctionBuilder.php b/lib/private/DB/QueryBuilder/FunctionBuilder/FunctionBuilder.php index e0a7549a0ad..408a879d624 100644 --- a/lib/private/DB/QueryBuilder/FunctionBuilder/FunctionBuilder.php +++ b/lib/private/DB/QueryBuilder/FunctionBuilder/FunctionBuilder.php @@ -121,4 +121,15 @@ class FunctionBuilder implements IFunctionBuilder { public function least($x, $y): IQueryFunction { return new QueryFunction('LEAST(' . $this->helper->quoteColumnName($x) . ', ' . $this->helper->quoteColumnName($y) . ')'); } + + public function case(array $whens, $else): IQueryFunction { + if (count($whens) < 1) { + return new QueryFunction($this->helper->quoteColumnName($else)); + } + + $whenParts = array_map(function (array $when) { + return 'WHEN ' . $this->helper->quoteColumnName($when['when']) . ' THEN ' . $this->helper->quoteColumnName($when['then']); + }, $whens); + return new QueryFunction('CASE ' . implode(' ', $whenParts) . ' ELSE ' . $this->helper->quoteColumnName($else) . ' END'); + } } |