Class CaseExpression
This class represents a SQL Case statement
Property Summary
-
$_conditions protected
array
A list of strings or other expression objects that represent the conditions of the case statement. For example one key of the array might look like "sum > :value"
-
$_elseValue protected
string|ExpressionInterface|array|null
The
ELSE
value for the case statement. If null then noELSE
will be included. -
$_values protected
array
Values that are associated with the conditions in the $_conditions array. Each value represents the 'true' value for the condition with the corresponding key.
Method Summary
-
__construct() public
Constructs the case expression
-
_addExpressions() protected
Iterates over the passed in conditions and ensures that there is a matching true value for each. If no matching true value, then it is defaulted to '1'.
-
_compile() protected
Compiles the relevant parts into sql
-
add() public
Adds one or more conditions and their respective true values to the case object. Conditions must be a one dimensional array or a QueryExpression. The trueValues must be a similar structure, but may contain a string value.
-
elseValue() public
Sets the default value
-
sql() public
Converts the Node into a SQL string fragment.
-
traverse() public
Iterates over each part of the expression recursively for every level of the expressions tree and executes the $visitor callable passing as first parameter the instance of the expression currently being iterated.
Method Detail
__construct() ¶ public
__construct(array|ExpressionInterface $conditions = [], array|ExpressionInterface $values = [], array $types = [])
Constructs the case expression
Parameters
-
array|ExpressionInterface
$conditions optional The conditions to test. Must be a ExpressionInterface instance, or an array of ExpressionInterface instances.
-
array|ExpressionInterface
$values optional associative array of values to be associated with the conditions passed in $conditions. If there are more $values than $conditions, the last $value is used as the
ELSE
value-
array
$types optional associative array of types to be associated with the values passed in $values
_addExpressions() ¶ protected
_addExpressions(array|ExpressionInterface $conditions, array|ExpressionInterface $values, array $types): void
Iterates over the passed in conditions and ensures that there is a matching true value for each. If no matching true value, then it is defaulted to '1'.
Parameters
-
array|ExpressionInterface
$conditions Must be a ExpressionInterface instance, or an array of ExpressionInterface instances.
-
array|ExpressionInterface
$values associative array of values of each condition
-
array
$types associative array of types to be associated with the values
Returns
void
_compile() ¶ protected
_compile(array|string|Cake\Database\ExpressionInterface $part, ValueBinder $generator): string
Compiles the relevant parts into sql
Parameters
-
array|string|Cake\Database\ExpressionInterface
$part The part to compile
-
ValueBinder
$generator Sql generator
Returns
string
add() ¶ public
add(array|ExpressionInterface $conditions = [], array|ExpressionInterface $values = [], array $types = []): $this
Adds one or more conditions and their respective true values to the case object. Conditions must be a one dimensional array or a QueryExpression. The trueValues must be a similar structure, but may contain a string value.
Parameters
-
array|ExpressionInterface
$conditions optional Must be a ExpressionInterface instance, or an array of ExpressionInterface instances.
-
array|ExpressionInterface
$values optional associative array of values of each condition
-
array
$types optional associative array of types to be associated with the values
Returns
$this
elseValue() ¶ public
elseValue(Cake\Database\ExpressionInterface|string|array|null $value = null, string $type = null): void
Sets the default value
Parameters
-
Cake\Database\ExpressionInterface|string|array|null
$value optional Value to set
-
string
$type optional Type of value
Returns
void
sql() ¶ public
sql(Cake\Database\ValueBinder $generator): string
Converts the Node into a SQL string fragment.
Parameters
-
Cake\Database\ValueBinder
$generator Placeholder generator object
Returns
string
traverse() ¶ public
traverse(callable $visitor): void
Iterates over each part of the expression recursively for every level of the expressions tree and executes the $visitor callable passing as first parameter the instance of the expression currently being iterated.
Parameters
-
callable
$visitor
Returns
void
Property Detail
$_conditions ¶ protected
A list of strings or other expression objects that represent the conditions of the case statement. For example one key of the array might look like "sum > :value"
Type
array
$_elseValue ¶ protected
The ELSE
value for the case statement. If null then no ELSE
will be included.
Type
string|ExpressionInterface|array|null
$_values ¶ protected
Values that are associated with the conditions in the $_conditions array. Each value represents the 'true' value for the condition with the corresponding key.
Type
array