Model.php
// Declare $datetime_limit
public datetime_limit;
Controller.php这样
// datetime_limit should be the actual datetime + 5 days
$criteria->select="DATE_ADD(NOW(), INTERVAL 5 DAY) AS datetime_limit";
错误讯息:
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.
编辑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);
答案 0 :(得分:4)
CActiveFinder::getColumnSelect
中会抛出此异常。
当CDbCriteria::$select
是一个字符串时,它被视为逗号分隔列的简单列表。您的表达式被解释为两个不同的列。您可以通过自己将select
设置为数组来解决此问题 - 在这种情况下,逗号拆分未完成 1 :
$criteria = new CDbCriteria();
$criteria->select = array("DATE_ADD(NOW(), INTERVAL 5 DAY) AS datetime_limit");
$models = Users::model()->findAll($criteria);
请注意,如果您编写的别名与公共模型属性或数据库字段不对应,则会检索它但会被忽略 - 由于某种原因,Yii不会为此抛出异常。
1 但是,此函数仍将尝试在表达式中查找.
并将其后面的部分解释为列标识符 - 不要在.
中使用{{1}}你的表达,你应该没事。