宿の予約システムを作ってみる
公開日:
:
FuelPHP
題名も新たに FuelPHP を勉強していきます。間違いを発見したら教えていただければ幸いです。
理由はわかりませんが、なんとなく FuelPHP を使うならモデルは Model_Crud が標準なのかな?と思い、ここも勉強して見ることにしました。素の Model は前回の記事を参照してください。今回はこれを書き換えてみます。
前回のモデル部分は
from('yado_base');
$query->where('id',$id);
return $query->execute()->as_array();
}
}
これを Model_Curd に書き換えると次のようになります。たぶん^^;
class Model_Base extends \Model_Crud
{
protected static $_table_name = 'yado_base';
protected static $_primary_key = 'id';
}
つまり基本的なSQL部分は既に定義されているので、あらためてモデル側で書く必要が無い?ということのようです。一応解説すると、上のtable_name が使用するMySQLのテーブル。下のprimary_keyはプライマリーキーと読んだまんまですね。ここで疑問が…複数のテーブルを使う場合は???
次はコントローラー側を修正します。前回のソースは
class Controller_Base extends Controller
{
public function action_test($id)
{
$base = new Model_Base();
$user = array();
$user['name'] = 'admin';
$user['query'] = $base->get_user($id);
return Response::forge( View::forge('base', $user) );
}
}
これが今回の場合は次のように変わります。
class Controller_Base extends Controller
{
public function action_test($id)
{
$data = array();
$data['rows'] = Model_Base::find_by_pk($id);
return View::forge('base', $data);
}
}
VIEWも変更します。
<?php foreach ($rows as $row): ?> ID : <?php echo $row['id']; ?>
名称 : <?php echo $row['name']; ?>
<?php endforeach; ?>
ここで「あれ?」っていう結果になりました。こんな時はプロファイラーを稼働させます。プログラム開発段階では、このプロファイリングが役立ちます。設定は app/config/config.php にあります。46行目近辺にある ’profiling’ => false, を ’profiling’ => true, とするだけです。ただし今回のようにデーターベースに関する情報を表示させるには、app/config/db.php も編集する必要があるようです。
'default' => array( 'type' => 'pdo', 'connection' => array( 'persistent' => false, ), 'identifier' => '`', 'table_prefix' => '', 'charset' => 'utf8', 'enable_cache' => true, 'profiling' => true, ), 'redis' => array( 'default' => array(
標準では ’profiling’ => false, となっています。これを上のように trueに変更します。app/config/development/db.php ではないのでご注意ください。

すると図のような感じで実行されたSQL文が確認できるようになります。便利♫
発行されたSQL文は
SELECT `yado_base`.* FROM `yado_base` WHERE `id` = '1' LIMIT 1 OFFSET 0 Possible keys: PRIMARY ·Type: system ·Rows: 1 ·Speed: 1.445 ms
出てきた画面は

SQL文に問題は無さそうだし、ためしにコントローラーの呼び出し部分を
$data['rows'] = Model_Base::find_one_by('id', $id);
と変えても変化がありません。ちなみにデーターベースには1件のみ登録されています…..(T_T) これはVIEWへのデータの渡し方がおかしいのではないか?VIEW側でやっていることは最低限だし。というわけでネットを徘徊しソースを検索。以下のように書換えたら成功しました。
$view = View::forge('base');
$data = array();
$data[] = Model_Base::find_by_pk($id);
$view->set('data', $data);
return $view;
VIEW側も調整
<?php foreach ($data as $row): ?> ID : <?php echo $row['id']; ?>
名称 : <?php echo $row['name']; ?>
<?php endforeach; ?>
まだまだ先は長い
Sponsored Link
関連記事
-
-
予定日より2日早く edelkrone FocusONE PROが届いたから開封編
晴天の土曜日。桜も終わり風も強くて、お出かけにはイマイチな感じ。こんな日はゆったり家で読書三昧でしょ
-
-
EOS MOVIEの終焉
Blackmagic Designのシネマカメラと5D3 の比較。こんなの見ちゃうと動画を考えてEO
-
-
車用メッシュのシートクッションでブラシレスジンバルケース
ここ数日、日差しの強い日が続いていてちょっと気持ちい感じですが、日本負けました(T_T) 落ち込んで
-
-
Panasonic GH3 でカラー調整してみる
近所にプラスチックダンボールが置いてあるか見に行ってきましたが、白だけ(T_T) キッチリサイズを計





ご質問は掲示板へお願いいたします。