程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> Zend Framework教程之Zend_Db_Table_Row用法實例分析

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

編輯:PHP綜合

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

1. 簡介

Zend_Db_Table_Row是Zend Framework的行數據網關.通常來說,你不可以自己實例化Zend_Db_Table_Row, 而是通過調用Zend_Db_Table::find()方法或者Zend_Db_Table::fetchRow()方法將Zend_Db_Table_Row作為 結果數據返回過來.一旦你得到來一個Zend_Db_Table_Row對象,你可以修改記錄值(體現為類的屬性)然後 調用save()方法可以將更改保存到原表上.

2. 取回一條記錄

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

<?php
// 設置一個 adapter
require_once 'Zend/Db.php';
$params = array (
  'host'   => '127.0.0.1',
  'username' => 'malory',
  'password' => '******',
  'dbname'  => 'camelot'
);
$db = Zend_Db::factory('PDO_MYSQL', $params);
// 為所有的Zend_Db_Table對象設置默認adapter
require_once 'Zend/Db/Table.php';
Zend_Db_Table::setDefaultAdapter($db);
// 連接到數據庫中的某一個表
class RoundTable extends Zend_Db_Table {}
$table = new RoundTable();
?>

接下來,使用Zend_Db_Table::find()方法和主鍵進行查詢,或者使 用Zend_Db_Table::fetchRow()方法查詢.
得到的返回結果是一個Zend_Db_Table_Row 對象,該對象的屬性名采用camelCaps的形式對應數據庫中帶下劃線的表名.
如,表名 若為first_name,那麼類中的改屬性則為firstName.

<?php
// 從表中取回的結果數據是一個Zend_Db_Table_Row對象
$row = $table->fetchRow('first_name = "Robin"');
//
// $row現在是一個帶有多種公有屬性的Zend_Db_Table_Row對象
// that map to table columns:
//
// $row->id = '3'
// $row->nobleTitle = 'Sir'
// $row->firstName = 'Robin'
// $row->favoriteColor = 'yellow'
//
?>

3. 修改數據

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

<?php
// 連接到數據庫中的表
class RoundTable extends Zend_Db_Table {}
$table = new RoundTable();
// 從表中取回的結果數據是一個Zend_Db_Table_Row對象
$row = $table->fetchRow('first_name = "Robin"');
//
// $row現在是一個帶有多種公有屬性的Zend_Db_Table_Row對象
// that map to table columns:
//
// $row->id = '3'
// $row->nobleTitle = 'Sir'
// $row->firstName = 'Robin'
// $row->favoriteColor = 'yellow'
//
// 改變favorite color字段,並且將變動存儲到數據表中.
$row->favoriteColor = 'blue';
$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('first_name = "Robin"');
// 我們嘗試修改主鍵值
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相關內容感興趣的讀者可查看本站專題:《Zend FrameWork框架入門教程》、《php優秀開發框架總結》、《Yii框架入門及常用技巧總結》、《ThinkPHP入門教程》、《php面向對象程序設計入門教程》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved