Oi pessoal, estou com problema com o CDbCriteria no projeto ThunderSnarf v1.1, vejam abaixo o código:
public function search() {
if (isset($_GET['pageSize'])) {
Yii::app()->user->setState('pageSize',(int)$_GET['pageSize']);
unset($_GET['pageSize']);
}
// Warning: Please modify the following code to remove attributes that
// should not be searched.
$criteria=new CDbCriteria;
if(!isset($_GET['Resumo'])) {
foreach($this->getAttributes() as $key=>$value) {
$this->setAttribute($key,'');
}
}else {
$dataA = date_parse($_GET['Resumo']['ultimaSolicitacaoA']);
$dataB = date_parse($_GET['Resumo']['ultimaSolicitacaoB']);
print_r($dataA);
print_r($dataB);
if(strlen($dataA['month'])==1) $dataA['month'] = '0'.$dataA['month'];
if(strlen($dataA['day'])==1) $dataA['day'] = '0'.$dataA['day'];
if(strlen($dataB['month'])==1) $dataB['month'] = '0'.$dataB['month'];
if(strlen($dataB['day'])==1) $dataB['day'] = '0'.$dataB['day'];
if(checkdate($dataA['month'], $dataA['day'], $dataA['year']) AND checkdate($dataB['month'], $dataB['day'], $dataB['year']) ) {
$criteria->condition = 'id_data BETWEEN '.$dataA['year'].$dataA['month'].$dataA['day'].' AND '.$dataB['year'].$dataB['month'].$dataB['day'].'';
}else if(checkdate($dataA['month'], $dataA['day'], $dataA['year'])) {
$criteria->condition = 'id_data >= '.$dataA['year'].$dataA['month'].$dataA['day'].'';
}else if(checkdate($dataB['month'], $dataB['day'], $dataB['year'])) {
$criteria->condition = 'id_data <= '.$dataB['year'].$dataB['month'].$dataB['day'].'';
}
}
$criteria->compare('requested',$this->requested);
$criteria->compare('cache_static',$this->cache_static);
$criteria->compare('cache_dynamic',$this->cache_dynamic);
$criteria->compare('traffic_static',$this->traffic_static);
$criteria->compare('traffic_dynamic',$this->traffic_dynamic);
$criteria->compare('hit_static',$this->hit_static);
$criteria->compare('hit_dynamic',$this->hit_dynamic);
$criteria->compare('miss_static',$this->miss_static);
$criteria->compare('miss_dynamic',$this->miss_dynamic);
$sort = new CSort();
if(isset($_GET["tipoTrafego"]) and $_GET["tipoTrafego"]=="E") {
$sort->defaultOrder = 'cache_static DESC';
if(!isset($_GET['sort'])) $_GET['sort'] = 'cache_static.desc';
}else if(isset($_GET["tipoTrafego"]) and $_GET["tipoTrafego"]=="D") {
$sort->defaultOrder = 'cache_dynamic DESC';
if(!isset($_GET['sort'])) $_GET['sort'] = 'cache_dynamic.desc';
}else {
if(isset($_GET['periodo']) AND $_GET['periodo']=="S") {//semanal
$sort->defaultOrder = 'id_data_week DESC';
if(!isset($_GET['sort'])) $_GET['sort'] = 'id_data_week.desc';
}else if(isset($_GET['periodo']) AND $_GET['periodo']=="M") {//mensal
$sort->defaultOrder = 'id_data_month DESC';
if(!isset($_GET['sort'])) $_GET['sort'] = 'id_data_month.desc';
}else {
$sort->defaultOrder = 'id_data DESC';
if(!isset($_GET['sort'])) $_GET['sort'] = 'id_data.desc';
}
}
if(isset($_GET['periodo']) AND $_GET['periodo']=="S") {//semanal
$criteria->select="(EXTRACT(WEEK FROM TO_DATE(TO_CHAR(id_data,'99999999'),'YYYYMMDD')) ||
'/' ||
EXTRACT(YEAR FROM TO_DATE(TO_CHAR(id_data,'99999999'),'YYYYMMDD'))) AS id_data_week,
SUM(cache_static) AS cache_static, SUM(cache_dynamic) AS cache_dynamic,
SUM(traffic_static) AS traffic_static, SUM(traffic_dynamic) AS traffic_dynamic,
SUM(hit_static) AS hit_static, SUM(hit_dynamic) AS hit_dynamic,
SUM(miss_static) AS miss_static, SUM(miss_dynamic) AS miss_dynamic,
SUM(requested) AS requested";
$criteria->group='id_data_week';
$sort->attributes['id_data_week'] = array(
'asc'=>'id_data_week',
'desc'=>'id_data_week desc');
}else if(isset($_GET['periodo']) AND $_GET['periodo']=="M") {//mensal
$criteria->select="(EXTRACT(MONTH FROM TO_DATE(TO_CHAR(id_data,'99999999'),'YYYYMMDD')) ||
'/' ||
EXTRACT(YEAR FROM TO_DATE(TO_CHAR(id_data,'99999999'),'YYYYMMDD'))) AS id_data_month,
SUM(cache_static) AS cache_static, SUM(cache_dynamic) AS cache_dynamic,
SUM(traffic_static) AS traffic_static,
SUM(traffic_dynamic) AS traffic_dynamic, SUM(hit_static) AS hit_static,
SUM(hit_dynamic) AS hit_dynamic,
SUM(miss_static) AS miss_static, SUM(miss_dynamic) AS miss_dynamic,
SUM(requested) AS requested";
$criteria->group='id_data_month';
$sort->attributes['id_data_month'] = array(
'asc'=>'id_data_month',
'desc'=>'id_data_month desc');
}
return new CActiveDataProvider('Resumo', array(
'criteria'=>$criteria,
'sort'=>$sort,
'pagination'=>array(
'pageSize'=> Yii::app()->user->getState('pageSize',Yii::app()->params['defaultPageSize']),
),
));
}
neste código acima, quando selecionado por semanal ou mensal, o select é alterado para adicionar os atributos conforme co que foi selecionado e é colocado um group by. Na versão 1.0 do yii funcionava, mas agora ele não está mais funcional na 1.1.4, pois ele apresenta o seguinte erro:
2010/10/08 11:01:34 [error] [system.db.CDbCommand] Error in querying SQL: SELECT COUNT(DISTINCT id_data_week) FROM "thundersnarf_data" "t" GROUP BY id_data_week
2010/10/08 11:01:34 [error] [exception.CDbException] exception 'CDbException' with message 'CDbCommand falhou ao executar o comando SQL: SQLSTATE[42703]: Undefined column: 7 ERROR: column "id_data_week" does not exist
LINE 1: SELECT COUNT(DISTINCT id_data_week) FROM "thundersnarf_data"...
^' in /usr/home/sette/workspace/thundersnarfopen_5/protected/yii114/framework/db/CDbCommand.php:387
Stack trace:
ele tenta fazer um "SELECT COUNT(DISTINCT" com o atributo que eu coloquei no group que é o id_data_week, mas este atributo não existe na minha tabela do POSTGRE, ele é um atributo do select criado para este group by, onde o SQL ficaria da seguinte maneira:
SELECT (EXTRACT(WEEK FROM TO_DATE(TO_CHAR(id_data,'99999999'),'YYYYMMDD')) || '/' || EXTRACT(YEAR FROM TO_DATE(TO_CHAR(id_data,'99999999'),'YYYYMMDD'))) AS id_data_week, SUM(cache_static) AS cache_static, SUM(cache_dynamic) AS cache_dynamic, SUM(traffic_static) AS traffic_static, SUM(traffic_dynamic) AS traffic_dynamic, SUM(hit_static) AS hit_static, SUM(hit_dynamic) AS hit_dynamic, SUM(miss_static) AS miss_static, SUM(miss_dynamic) AS miss_dynamic, SUM(requested) AS requested FROM thundersnarf_data GROUP BY id_data_week;
id_data_week | cache_static | cache_dynamic | traffic_static | traffic_dynamic | hit_static | hit_dynamic | miss_static | miss_dynamic | requested
--------------+--------------+---------------+----------------+-----------------+------------+-------------+-------------+--------------+-----------
19/2010 | 131691438 | 2800197834 | 65638291 | 1733035380 | 12210 | 4517 | 5059 | 48614 | 70400
(1 row)
O comando SQL Acima funciona perfeitamente como vocês podem ver, mas o CDbCriteria tenta fazer o "SELECT COUNT(DISTINCT" antes, como faço para que ele não execute este COUNT??? Tentei até desativar o controle de paginação, mas mesmo assim ele tenta fazer o COUNT.
Alguem sabe uma solução? Aceito qualquer tipo de gambiarra recurso técnico , sendo funcional é o que importa