首页 > 解决方案 > CakePHP 3.x 所有查询的默认模型条件

问题描述

我找到了多种 CakePHP 2.x 的解决方案(例如在 Model 中定义全局条件)和 CakePHP 3.x 控制器查询的解决方案: $this->Articles->find('all', ['conditions' => ['domain =' => $this->request->host()]]);但模型中的 CakePHP 3.x 全局查询条件没有。当我使用

function beforeFind($event, $queryData, $options) {
    $queryData['conditions'][]['NOT'][$this->alias . '.parent_id'] = null;
    return $queryData;
}

我得到错误Cannot use object of type Cake\ORM\Query as array

标签: cakephpcakephp-3.x

解决方案


好的,经过几个小时的搜索,我找到了一个非常简单的解决方案:

public function beforeFind($event, $query, $options) {  
      $query->where(['field_name' => 'field_value']);
      return $query;
}

或内部 initialize() :

class MyClassTable extends Table
{

    /**
     * Initialize method
     *
     * @param array $config The configuration for the Table.
     * @return void
     */
    public function initialize(array $config)
    {
        parent::initialize($config);

        $this->setTable('table_name');
        $this->setDisplayField('title');
        $this->setPrimaryKey('id');

        $this->addBehavior('Timestamp');    

        $this->belongsTo('OtherClass', [
            'foreignKey' => 'class_id',
            'joinType' => 'INNER'
        ])->setConditions(['class_name' => 'any_value']);

    }
}

推荐阅读