首頁 >php教程 >PHP开发 >Zend Framework教程之Zend_Db_Table_Row用法实例分析

Zend Framework教程之Zend_Db_Table_Row用法实例分析

高洛峰
高洛峰原創
2017-01-05 09:49:591248瀏覽

本文實例講述了Zend Framework教程之Zend_Db_Table_Row用法。分享給大家供大家參考,具體如下:

1. 簡介

Zend_Db_Table_Row是Zend Framework的行資料閘道.通常來說,你不可以自己實例化Zend_Db_Table_Row, 而是透過呼叫Zend_Db_Table::find(Db_Table::find)或方法或方法或方法Zend_Db_Table::fetchRow()方法將Zend_Db_Table_Row作為結果資料回傳過來.一旦你得到來一個Zend_Db_Table_Row物件,你可以修改記錄值(體現為類別的屬性)然後呼叫save()方法可以將變更儲存到原表上.

2. 取回一筆記錄

首先,需要實例化一個Zend_Db_Table類.

<?php
// 设置一个 adapter
require_once &#39;Zend/Db.php&#39;;
$params = array (
  &#39;host&#39;   => &#39;127.0.0.1&#39;,
  &#39;username&#39; => &#39;malory&#39;,
  &#39;password&#39; => &#39;******&#39;,
  &#39;dbname&#39;  => &#39;camelot&#39;
);
$db = Zend_Db::factory(&#39;PDO_MYSQL&#39;, $params);
// 为所有的Zend_Db_Table对象设置默认adapter
require_once &#39;Zend/Db/Table.php&#39;;
Zend_Db_Table::setDefaultAdapter($db);
// 连接到数据库中的某一个表
class RoundTable extends Zend_Db_Table {}
$table = new RoundTable();
?>

接下來,使用Zend_Db_Table::find()方法和主鍵進行查詢,或使用Zend_Db_TablefetchetchRow()::fetch得到的回傳結果是一個Zend_Db_Table_Row 物件,該物件的屬性名稱採用camelCaps的形式對應資料庫中帶下劃線的表名.
如,表名若為first_name,那麼類別中的改屬性則為firstName.

<?php
// 从表中取回的结果数据是一个Zend_Db_Table_Row对象
$row = $table->fetchRow(&#39;first_name = "Robin"&#39;);
//
// $row现在是一个带有多种公有属性的Zend_Db_Table_Row对象
// that map to table columns:
//
// $row->id = &#39;3&#39;
// $row->nobleTitle = &#39;Sir&#39;
// $row->firstName = &#39;Robin&#39;
// $row->favoriteColor = &#39;yellow&#39;
//
?>

3 .修改資料

修改行資料是一件很輕鬆的事情:只需要按照常規的方法修改類別屬性.然後調用save()方法就將改變的結果保存到了數據表中.

<?php
// 连接到数据库中的表
class RoundTable extends Zend_Db_Table {}
$table = new RoundTable();
// 从表中取回的结果数据是一个Zend_Db_Table_Row对象
$row = $table->fetchRow(&#39;first_name = "Robin"&#39;);
//
// $row现在是一个带有多种公有属性的Zend_Db_Table_Row对象
// that map to table columns:
//
// $row->id = &#39;3&#39;
// $row->nobleTitle = &#39;Sir&#39;
// $row->firstName = &#39;Robin&#39;
// $row->favoriteColor = &#39;yellow&#39;
//
// 改变favorite color字段,并且将变动存储到数据表中.
$row->favoriteColor = &#39;blue&#39;;
$row->save();
?>

但是,你不能夠修改主鍵的值.假如你試圖進行改操作, Zend_Db_Table_Row將拋出一個異常.

<?php
// 连接到数据库中的表
class RoundTable extends Zend_Db_Table {}
$table = new RoundTable();
// fetch a record from the table as a Zend_Db_Table_Row object
$row = $table->fetchRow(&#39;first_name = "Robin"&#39;);
// 我们尝试修改主键值
try {
  $row->id = 5;
  echo "We should not see this message, as an exception was thrown.";
} catch (Zend_Db_Table_RowException $e) {
  echo $e->getMessage();
}
?>

希望本文所述對大家基於Zend Framework框架的PHP程式設計有所幫助。

更多Zend Framework教程之Zend_Db_Table_Row用法實例分析相關文章請關注PHP中文網!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn