cakePHP4にて以下のように一覧ページを実装しています。
コンテンツをタグで検索、一覧表示する機能をつけたいと思い、paginateの変数での条件指定をつかった実装を試みています。
cakePHP4
1class ItemsController extends AppController 2{ 3 /** 4 * Index method 5 * 6 * @return \Cake\Http\Response|null|void Renders view 7 */ 8 public $defaultCondition = "all"; 9 10 public $paginate = [ 11 'limit' => 20, 12 'order' => [ 13 'Articles.title' => 'asc' 14 ], 15 'conditions' => [ 16 'Items.tag LIKE' => "%" 17 ] //デフォルトでは全件検索 18 ]; 19
この中でSQL文に当たる"conditions"を、アクションの中から変更したいのですが、そのやり方がわかりません。
cakePHP4
1public function showcase(){ 2 $paginate['conditions'] = [ 3 'Items.tag' => "食べ物" 4 ]; //ここで条件を変更する。この場合はtag="食べ物" 5 6 7 $items = $this->paginate($this->Items); 8 $this->set("items",$items); 9 10 //ログの処理 11 $IP = $_SERVER["REMOTE_ADDR"]; 12 $Device = $_SERVER["HTTP_USER_AGENT"]; 13 $this ->log("IPアドレス=".$IP." 端末=".$Device, "info"); 14 //ここまでログ 15 16 } 17
理屈だけで考えると、ItemsContollerの$paginateの変数を上書きすることで条件を変えられそうなのですが、これだとうまく機能してくれません。何が原因なのでしょうか...?
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。