Files
kiri-core/Database/Traits/When.php
T

78 lines
1.2 KiB
PHP
Raw Normal View History

2021-03-26 14:53:47 +08:00
<?php
namespace Database\Traits;
use Database\ActiveQuery;
2021-08-09 17:02:20 +08:00
use Database\ISqlBuilder;
2021-03-26 14:53:47 +08:00
use Exception;
use JetBrains\PhpStorm\Pure;
/**
* Class CaseWhen
* @package Database\Traits
*/
2021-03-26 14:59:24 +08:00
class When
2021-03-26 14:53:47 +08:00
{
2021-08-09 17:02:20 +08:00
public ActiveQuery|ISqlBuilder $query;
2021-03-26 14:53:47 +08:00
private array $_condition = [];
private string $else = '';
/**
* CaseWhen constructor.
* @param string $column
2021-08-09 17:02:20 +08:00
* @param ActiveQuery|ISqlBuilder $activeQuery
2021-03-26 14:53:47 +08:00
*/
2021-08-09 17:02:20 +08:00
public function __construct(public string $column, public ActiveQuery|ISqlBuilder $activeQuery)
2021-03-26 14:53:47 +08:00
{
$this->_condition[] = 'CASE ' . $column;
}
/**
2021-08-09 17:14:55 +08:00
* @param string|int $condition
2021-03-26 14:53:47 +08:00
* @param string $then
* @return $this
* @throws Exception
*/
2021-08-09 17:14:55 +08:00
public function when(string|int $condition, string $then): static
2021-03-26 14:53:47 +08:00
{
2021-08-09 17:14:55 +08:00
$this->_condition[] = sprintf('WHEN %s THEN %s', $condition, $then);
2021-03-26 14:53:47 +08:00
return $this;
}
/**
* @param string $alias
*/
public function else(string $alias)
{
$this->else = $alias;
}
/**
* @return string
*/
#[Pure] public function end(): string
{
if (empty($this->_condition)) {
return '';
}
$prefix = implode(' ', $this->_condition);
if (!empty($this->else)) {
$prefix .= ' ELSE ' . $this->else;
}
2021-08-10 10:52:05 +08:00
return '(' . $prefix . ' END)';
2021-03-26 14:53:47 +08:00
}
}