findAllByAreaGroupId を使って、検索して取得するパターン
■Model
find 系を使うので特に変更なし
■Controller
/Store?group=10 でアクセスできるようにコントローラを作成
in Controller/StoreController.php
class StoreController extends AppController { public function index() { $id = null; $group = null; if (isset($this->params['url']['id'])) $id = $this->params['url']['id']; if (isset($this->params['url']['group'])) $group = $this->params['url']['group']; if ( $id != null ) { $this->set('Store',$this->Store->findAllById($id)); } else if ( $group != null ) { $this->set('Store',$this->Store->findAllByAreagroupid($group)); } else { $this->set('Store', $this->Store->find('all',array('limit'=>'100'))); } } }
パラメータで取得するので、$this->params[‘url’][‘group’] を使う。isset チェックを忘れずに。
PK ではないので、数百行返される可能性もあるので、limit をつけたほうがベターかも。
findAllByAreagroupid のところは、findAllByAreaGroupId のように書きたいところだが、このように書くと「area_group_id」のように展開されてしまうので「Areagroupid」のようにすべて小文字で書く。
limit を使おうとすると、conditions を指定しないとだめで、
$this->set('Store', $this->Store->find('all', array( 'limit' => 10, 'conditions' => array('AreaGroupId'=>$group))));
な風に長くなる。なんらかのヘルパー関数が必要かも…って慣れれば大丈夫?
■View
戻り値は配列になるので、foreach のところはそのままで。
■結果
指定したグループの最初の10件が表示されている(conditions を使ったパターン)。