[英]Yii - Query Manipulation for Custom CGridView with Advanced Search
因此,我扩展了CGridView,以包含根据我的组织需求量身定制的高级搜索功能。
版本1工作,虽然很慢。 基本上,我参与了CGridView的内部工作,在那里我从DataProvider中抓取结果并在渲染表内容之前在PHP中进行搜索和排序。
现在编写第2版,我的目标是专注于聪明的CDbCriteria创建,允许MySQL进行繁重的工作,以便更快地运行。 在处理单个数据库表时,实现是微不足道的。 当我处理2个或更多表时出现困难...例如,如果用户想要搜索STAT关系的字段,我需要在我的查询中出现该关系,以便我可以包括比较。
这是问题所在。 如何保证Yii的包括所有with
我的查询中的关系,使我有比较? 我已经在模型的search
功能中包含了我的所有关系with
条件,并且我已经尝试将CDbCriteria together
设置为true ...
public function search() {
$criteria=new CDbCriteria;
$criteria->compare('id', $this->id);
$criteria->compare( ...
...
$criteria->with = array('relation0','relation1','relation3');
$criteria->together = true;
return new CActiveDataProvider(
get_class($this), array(
'criteria'=>$criteria,
'pagination' => array('pageSize' => 50)
));}
然后我将从DataProvider中抢夺条件并添加一些条件 ,例如,查找日期> 1234567890.但我仍然会收到这样的错误...
CDbCommand failed to execute the SQL statement:
SQLSTATE[42S22]: Column not found: 1054 Unknown column 't.relation3' in 'where clause'.
The SQL statement executed was:
SELECT COUNT(DISTINCT `t`.`id`) FROM `table` `t`
LEFT OUTER JOIN `relation_table` `relation0` ON (`t`.`id`=`relation0`.`id`)
LEFT OUTER JOIN `relation_table` `relation1` ON (`t`.`id`=`relation1`.`id`)
WHERE (`t`.`relation3` > 1234567890)
其中relation0
和relation1
是BELONGS_TO
关系,但缺少任何STAT
关系,此处描述为relation3
。 此外,为什么查询是SELECT COUNT(DISTINCT 't'.'id')
?
编辑 @DCoder这是我现在正在使用的具体关系。 主表是Call,它与HAS_MANY
有HAS_MANY
关系,可以保持时间。 因此,Call的startTime
是所有相关CallSegments的最小start_time。 而startTime
是我匿名查询错误中的假设relation3
。
'startTime' => array(self::STAT, 'CallSegments', 'call_id',
'select' => 'min(`start_time`)'),
编辑其他人已经把我送到了CDbCriteria的together
财产 ,但正如你在上面所看到的,我目前正在尝试这一点无济于事。
从标准中抢夺sql并自行使用它并不是一个好主意。
如果您使用“with”属性,那么您可以轻松地使用如下比较:
$criteria->compare("`relation1`.`id`", $yourVarHere);
Yii在分组方面也表现不佳。
我与STAT关系的方法是在Yii的选择中使用子查询,然后是:
$criteria->select = array("`t`.*", "(SELECT COUNT(*) FROM `relation3` WHERE `id` = `t`.id_relation3) AS `rel3`");
$criteria->having = "`rel3` > " . $yourValue;
上面的方法在gridview分页中创建了一个错误,因为计数是在不同的查询上完成的。 解决方法是删除“with”属性并在“join”属性中自行编写连接,如:
$criteria->join = "LEFT OUTER JOIN `relation_table` `relation0` ON (`t`.`id`=`relation0`.`id`)
LEFT OUTER JOIN `relation_table` `relation1` ON (`t`.`id`=`relation1`.`id`)
LEFT OUTER JOIN `relation_table` `relation3` ON (`t`.`id`=`relation3`.`id`)";
如果bug有点难以开始工作,你可以使用stat关系作为简单的HAS_ONE:
'select'=>'count(relation3.id)',
'joinType'=>'left join',
'group'=>'relation3.id',
'on'=>'t.id = relation3.id',
'together'=>true
将计数值与其他所有东西一起排除?
不确定这对你的情况有多好,但它不时对我有帮助。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.