CakePHP 3.x所有查询的默认模型条件

问题描述 投票:0回答:1

我找到了CakePHP 2.x的多个解决方案(例如这里的Defining global conditions in 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

cakephp cakephp-3.x
1个回答
0
投票

好吧,经过几个小时的搜索,我发现了一个非常简单的解

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']);

    }
}
© www.soinside.com 2019 - 2024. All rights reserved.