Store というテーブルがあるとして、
■Model
テーブル名を複数形にしたくない(既存のテーブル名を変えたくない)ので、$useTable で指定
in Model/Store.php
class Store extends AppModel
{
var $useTable = 'Store'; // 対象テーブル名を指定
}
find 系の関数だけを使うのであれば、最初は空で ok 。
■Controller
/Store でアクセスできるようにコントローラを作成
in Controller/StoreController.php
class StoreController extends AppController {
public function index() {
$this->set('Store', $this->Store->find('all',array('limit'=>'100')));
}
}
全件検索すると1万行ぐらいあるので、最初の100行で打ち切り。find でリミットを指定できるのだけど、ここは「安全」にコーディングするために、find100 とかいうメソッドでアクセスしたほうがよいかも。
class StoreController extends AppController {
public function index() {
$this->set('Store', $this->Store->find100());
}
}
この場合は、Model/Store.php に find100 メソッドを追加する。
class Store extends AppModel
{
var $useTable = 'Store';
function find100()
{
$sql = <<< HERE
SELECT
ID, AreaGroupID, Name
FROM Store
limit 0,100
HERE;
return $this->query($sql);
}
}
こうやって SQL 文を直書きする。
■View
Controller で設定 $this->set(‘Store’,…) したところが使えるので、そのまま foreach でループさせる。
in View/Store/Index.ctp
store index の表示 <h2>Store list</h2> <table> <tr> <td>id</td> <td>areagroupid</td> <td>name</td> </tr> <!-- <?php print_r( $Store ); ?> --> <?php foreach($Store as $item) : ?> <tr> <td><?php echo $item['Store']['ID'] ?></td> <td><?php echo $item['Store']['AreaGroupID'] ?></td> <td><?php echo $item['Store']['Name'] ?></td> </tr> <?php endforeach ; ?>
■結果
先頭の 100 件だけ表示する。

