いつもお世話になっております。
Cakephp4の学習を進めているのですが、詰まったところがあるので教えてください。
表題のとおり、belongsToでアソシエーションしているモデルで
アソシエーション元とアソシエーション先にそれぞれ取得するフィールドを制限するにはどうすればよいのでしょうか?
select文を入れると、containが無視されてアソシエーション先の情報が取得できません。
HogeTable
1public function initialize(array $config): void 2 { 3 parent::initialize($config); 4 5 $this->setTable('hoge'); 6 $this->setPrimaryKey('id'); 7 8 $this->belongsTo('hoge1'); 9 $this->belongsTo('hoge2'); //カラム数が多い 10 $this->belongsTo('hoge3'); 11 }
controller
1 2$user = $this->HogeModel->find() 3 ->where(['login_id' => $this->request->getData('login_id')]) 4 ->select(['id', 'center_id', 'name']) 5 ->contain(['Hoge1', 'Hoge2', 'Hoge3']) 6 ->first(); 7 8 9/** 10 * 結果:containが無視されて、HogeModelのもののみ取得される 11 * ※->select ~ をコメントアウトすると、containが含まれるのを確認済み 12 */ 13 14//---下記のように、containの中で指定すれば取得することはできる 15// ただ、Hoge2などはカラム数が多く、その全てが必要なので指定せずにすませたい 16// ->contain(['Hoge1' => function($q){ 17// return $q->select(['id', 'area_id', 'name', 'short_name']); 18// }, 'Hoge2', 'Hoge3']); 19
以上、宜しくお願い致します。
あなたの回答
tips
プレビュー