2011-08-18 5 views
0

J'essaie d'utiliser requête personnalisée dans Cake paginer ensuite les résultats avec le code ci-dessous:CakePHP pagination requête personnalisée

$query = $this->Petition->query($sql); 

I Tried:

$petitions = $this->paginate($query); 

et il ne fonctionne pas. Y a-t-il un moyen de le faire?

OK Je n'étais pas assez clair: j'ai besoin d'utiliser une matrice variable récupérée à partir de requêtes personnalisées sur la pagination afin que je puisse l'utiliser pour la pagination dans la vue. Y a-t-il un moyen facile de faire ça? Ci-dessous mon code:

function index() { 
     if ($this->Session->read('Auth.User.group_id') != 1) { 
      $commune_id = $this->Session->read('Auth.User.commune_id'); 
      $commune_id = $this->Petition->Commune->findbyId($commune_id); 
      $commune_id = $this->Petition->Commune->find('all',array('conditions' => array('group' => $commune_id['Commune']['group']))); 
      $count = count($commune_id); 
      $i=1; 
      $sql = "SELECT * FROM `petitions` WHERE `commune_id` = "; 
      foreach($commune_id as $commune_ids){ 
       if($i==1){ 
       $sql .= $commune_ids['Commune']['id']; 
       }else{ 
       $sql .= " OR `commune_id` = ".$commune_ids['Commune']['id']; 
       } 
      /*if($i != $count){ 
      $this->paginate = array(
       'or' => array(
        array('Petition.commune_id LIKE' => $commune_ids['Commune']['id'] . ","), 
        //array('Petition.commune_id LIKE' => "," . $commune_ids['Commune']['id'] . ",") 
        ), 
       'limit' => 10 
      ); 
      }*/ 
      $i++; 
      } 
      $query = $this->Petition->query($sql); 
     } 
     $this->Petition->recursive = 0; 
     $petitions = $this->paginate(); 
     $this->set('petitions', $petitions); 
    } 

Répondre

0

vous avez besoin sérieusement de lire la partie dans le livre pagination gâteau:

function index() { 
    $conditions = array(); 
    if ($this->Auth->user('group_id') != 1) { 
     $commune_id = $this->Petition->Commune->findById($this->Auth->user('commune_id')); 
     $conditions['Petition.id'] = $this->Petition->Commune->find('list',array(
      'fields'=>array('id','id') 
      'conditions' => array('group' => $commune_id['Commune']['group']) 
     )); 
    } 
    $this->Petition->recursive = 0; 
    $petitions = $this->paginate('Petition',$conditions); 
    $this->set('petitions', $petitions); 
} 

quelque chose comme ça.

0

ce n'est pas comment fonctionne vous pagination besoin de remplir $ this-> valider avec vos conditions etc puis utilisez $ this-> paginate() clairement

voir http://book.cakephp.org/view/1232/Controller-Setup

Notez également le chapitre sur la partie de requête personnalisée si elle est vraiment (!) Nécessaire.

+1

vouliez-vous dire '$ this-> paginate' au lieu de' $ this-> validate' ?? – pleasedontbelong