Problemas com group no CDbCriteria

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 B)

Cara, o CActiveDataProvider ta montando sua SQL errada. Ok, vc já deve ter reparado isso tb.

O problema aqui, é o SQL de contágem, que da dando problemas.

Não sei se é este o problema, mas vai um chute, que eu acho que talvez acerte.

no model que vc está pesquisando, tente declarar essa função abaixo


public function count($condition='',$params=array()){

   return 100

}

isso vai desabilitar a contágem por SQL, retornando como se sempre tivessem 100 registros.

Tente fazer isso e poste aqui pra ver se o erro persiste. Se funcionar, tentamos melhorar isso ai pra acertar a contágem de registros depois.

Brigadão, realmente é o problema da contagem, pois como eu tinha demonstrado, ele tenta fazer uma contagem com um atributo que não existe na tabela do banco, pois é um atributo criado em meu SELECT, o que eu não tinha encontrado ainda era uma gambiarra recurso técnico para isso.

Declarando esta função que você passou funcionou perfeitamente, já que redeclaramos a função de contagem retornando sempre 100, um perfeito recurso técnico B) .

Agora é saber como fazer sem perder a contagem real da consulta.

Chutei no ângulo :)

Bom, descobrimos um bug. Seria bom postar no site, pra ver se os matedores do Yii conseguem uma solução. Eu não to vendo nenhuma daqui por enquanto.