[CakePHP] 最初のひな形を作る

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 件だけ表示する。

カテゴリー: CakePHP パーマリンク