2014-09-11 79 views
-2

我有一个项目的问题,我需要复制一些行,但不是在数据库中,我需要做之后做一个选择查询,我试图做一个代码在该方法找到了模型后,但我认为分页确实工作后,发现我是对的?所以当我尝试修改包含我的结果,订单丢失的阵列和永远不会再工作......我的代码是这样的......CakePHP afterFind和分页顺序不起作用

public function afterFind($results) { 
    foreach ($results as $rKey = $result) { 
     if (count ($result['Address']) 1) { 
      foreach ($result['Address'] as $address) { 
       $res[] = array('Client' => $result['Client'], 
        'Address' => $address 
       ); 
       unset($results[$rKey]); 

      } 

     } 

    } 

    return $res; 
} 

所以,这是给有分页的问题.. 。有人能帮我吗??谢谢...

修订

在模型:

公共$为了=阵列( 'Cliente.is_anunciante'=> 'DESC', 'Cliente.nome_fantasia'=>' ASC');

public function paginate(
    $conditions, $fields, $order, $limit, $page = 1, 
    $recursive = null, $extra = array() 
) { 

    $results = $this->getResults($conditions, $fields, $order, $limit, $page, $recursive, $extra); 

    return $results; 

} 

public function paginateCount($conditions = null, $recursive = 0, $extra = array()) { 

    $results = $this->getResults($conditions, $recursive, $extra, null, null, null, null); 

    return count($results); 

} 

public function getResults($conditions, $fields, $order, $limit, $page, $recursive, $extra) { 

    if(!empty($page)) 
     $results = $this->find('all', compact('conditions', 'fields', 'order', 'limit', 'page', 'recursive', 'group')); 

    if(empty($page)) 
     $results = $this->find('all', compact('conditions', 'recursive', 'extra')); 

    foreach ($results as $rKey => $result) { 

     if(!empty($result['Endereco']) && count($result['Endereco']) > 1 && $result['Cliente']['is_anunciante'] != 2){ 

      foreach ($result['Endereco'] as $key => $endereco) { 

       $results[] = array(
        'Cliente' => $result['Cliente'], 
        'Endereco' => array(
         $endereco 
        ) 
       ); 

      } 

      unset($results[$rKey]); 

     } 

    } 

    return $results; 

} 

在控制器的动作里面:

$this->paginate = array(
'limit' => 20, 
'order' => array(
    'is_anunciante' => 'DESC', 
    'nome_fantasia' => 'ASC' 
) 
); 
+0

它的原因是paginateCount方法不知道你要添加多少行,使用patryate和paginateCount方法覆盖它们。 – 2014-09-11 03:03:11

+0

如果页面为空,那么'$ limit'是什么? – 2014-09-18 03:07:18

回答

0

尝试这样做 -

public function paginate(
    $conditions, $fields, $order, $limit, $page = 1, 
    $recursive = null, $extra = array() 
) { 
    return $this->getResults($conditions, $limit, $page, $order); 
} 

getResults将获取行并进行修改。

public function paginateCount($conditions = null, $recursive = 0, $extra = array()) 
{ 
    $results = $this->getResults($conditions, $limit, $page, $order); 
    return count($results); 
} 
+0

谢谢你,我把这个代码放在哪里?我只是把它放在我的模型上? – user3707567 2014-09-11 13:15:21

+0

我认为你的意思是我应该重写这些分页组件的方法......就是这样?请评论这一点,我认为你是对的,它可以工作... – user3707567 2014-09-12 00:42:42

+0

是的..并写在你的模型中。 – 2014-09-12 03:46:17