将值传递给模型中的自定义查找


passing values to custom find in Model

我在模型中有以下自定义查找,我想根据传递给它的值重复使用。

 public function _findActive($state, $query, $result = array()) {
        if ($state === 'before') {
            $query['conditions'] = array('WebRequest.status' => false, 'WebRequest.read_status' => false);
            $query['contain'] = false;
            $query['limit'] = 25;
            $query['order'] = array('WebRequest.created' => 'asc');
            return $query;
        }
        return $result;
    }

我可以从我的控制器调用这个函数,它会将结果分页为每页25个。然而,我希望能够将限制值传递给函数,并根据需要按每页的音量进行限制。我可以向传递到函数中的函数参数($state, $query, $result = array(), $limit)添加额外的字段$limit。如果我在if($state === 'before')的函数开始时进行调试,那么该值将保持传入时的状态,但由于该函数被自动调用两次,默认情况下,在第二次调用该函数时,它会重置回null,因此我会丢失传入的值。有什么办法解决这一问题吗?

试试这个:

public function _findActive($state, $query, $result = array()) {
    if ($state === 'before') {
        $query['conditions'] = array(
          'WebRequest.status' => false,
          'WebRequest.read_status' => false
        );
        $query['contain'] = false;
        $query['limit'] = 25;
        $query['order'] = array('WebRequest.created' => 'asc');
        return $query;
    } elseif ($state == 'after') {
       return $results;
    }
}`

您可以将原始$limit值存储在模型中的私有类变量中,并将其用于限制。类似于:

class YourModel extends AppModel {
   private $_originalLimit;
   public function _findActive($state, $query, $result = array, $limit) {
      ....
      if (!empty($limit))
         $this->_originalLimit = $limit;
      $query['limit'] = $this->_originalLimit;
      ....
   }
}

当使用空$limit第二次调用此函数时,您的类变量(具有原始$limit值)将用于限制。