类 yii\db\conditions\BetweenColumnsConditionBuilder
类 BetweenColumnsConditionBuilder 构建 yii\db\conditions\BetweenColumnsCondition 对象
公共方法
方法 | 描述 | 定义于 |
---|---|---|
__construct() | ExpressionBuilderTrait 构造函数。 | yii\db\ExpressionBuilderTrait |
build() | 该方法从 $expression 构建原始 SQL,不会额外转义或引用。 | yii\db\conditions\BetweenColumnsConditionBuilder |
受保护方法
方法 | 描述 | 定义于 |
---|---|---|
createPlaceholder() | 将 $value 附加到 $params 数组并返回占位符。 | yii\db\conditions\BetweenColumnsConditionBuilder |
escapeColumnName() | 准备要在 SQL 语句中使用的列名。 | yii\db\conditions\BetweenColumnsConditionBuilder |
方法详情
定义于: yii\db\ExpressionBuilderTrait::__construct()
ExpressionBuilderTrait 构造函数。
public void __construct ( yii\db\QueryBuilder $queryBuilder ) | ||
$queryBuilder | yii\db\QueryBuilder |
public function __construct(QueryBuilder $queryBuilder)
{
$this->queryBuilder = $queryBuilder;
}
该方法从 $expression 构建原始 SQL,不会额外转义或引用。
public string build ( yii\db\ExpressionInterface $expression, array &$params = [] ) | ||
$expression | yii\db\ExpressionInterface|yii\db\conditions\BetweenColumnsCondition |
要构建的表达式。 |
$params | array |
绑定参数。 |
返回值 | string |
不会额外转义或引用的原始 SQL。 |
---|
public function build(ExpressionInterface $expression, array &$params = [])
{
$operator = $expression->getOperator();
$startColumn = $this->escapeColumnName($expression->getIntervalStartColumn(), $params);
$endColumn = $this->escapeColumnName($expression->getIntervalEndColumn(), $params);
$value = $this->createPlaceholder($expression->getValue(), $params);
return "$value $operator $startColumn AND $endColumn";
}
将 $value 附加到 $params 数组并返回占位符。
protected string createPlaceholder ( $value, &$params ) | ||
$value | mixed | |
$params | array |
按引用传递 |
protected function createPlaceholder($value, &$params)
{
if ($value instanceof ExpressionInterface) {
return $this->queryBuilder->buildExpression($value, $params);
}
return $this->queryBuilder->bindParam($value, $params);
}
准备要在 SQL 语句中使用的列名。
protected string escapeColumnName ( $columnName, &$params = [] ) | ||
$columnName | yii\db\Query|yii\db\ExpressionInterface|string | |
$params | array |
绑定参数。 |
protected function escapeColumnName($columnName, &$params = [])
{
if ($columnName instanceof Query) {
list($sql, $params) = $this->queryBuilder->build($columnName, $params);
return "($sql)";
} elseif ($columnName instanceof ExpressionInterface) {
return $this->queryBuilder->buildExpression($columnName, $params);
} elseif (strpos($columnName, '(') === false) {
return $this->queryBuilder->db->quoteColumnName($columnName);
}
return $columnName;
}
注册 或 登录 以发表评论。