如何在 Yii $criteria 中使用 DATE_ADD?

Luc*_*nto 5 php yii

模型.php

// Declare $datetime_limit
public datetime_limit;
Run Code Online (Sandbox Code Playgroud)

控制器.php

// datetime_limit should be the actual datetime + 5 days
$criteria->select="DATE_ADD(NOW(), INTERVAL 5 DAY) AS datetime_limit";
Run Code Online (Sandbox Code Playgroud)

错误信息:

Active record "Users" is trying to select an invalid column "DATE_ADD(NOW()". Note, the column must exist in the table or be an expression with alias.
Run Code Online (Sandbox Code Playgroud)

编辑1:

我想使用关系表(多对多)过滤带有条件的查找。所以datetime_limit不能有关系events.datetime。我怎样才能做到这一点?

$criteria->select=array("DATE_ADD(NOW(), INTERVAL 5 DAY) AS datetime_limit");
$criteria->with=array('events');
$criteria->having='datetime_limit!=`events`.`datetime`';
$models=Users::model()->findAll($criteria);
Run Code Online (Sandbox Code Playgroud)

DCo*_*der 5

此异常在CActiveFinder::getColumnSelect.

WhenCDbCriteria::$select是一个字符串,它被视为以逗号分隔的列的简单列表。您的表达式被解释为两个不同的列。您可以通过select自己设置数组来解决此问题- 在这种情况下,逗号拆分未完成1

$criteria = new CDbCriteria();
$criteria->select = array("DATE_ADD(NOW(), INTERVAL 5 DAY) AS datetime_limit");
$models = Users::model()->findAll($criteria);
Run Code Online (Sandbox Code Playgroud)

请注意,如果您编写的别名与公共模型属性或数据库字段不对应,它将被检索但会被静默忽略 - 由于某种原因 Yii 不会为此抛出异常。


1但是,此函数仍会尝试.在表达式中查找 a并将其后的部分解释为列标识符 - 不要.在您的表达式中使用,您应该没问题。