溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Zend_Db_Table_Row如何在Zend Framework中使用

發(fā)布時間:2021-04-02 16:21:52 來源:億速云 閱讀:105 作者:Leah 欄目:開發(fā)技術(shù)

這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)Zend_Db_Table_Row如何在Zend Framework中使用,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

1. 簡介

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

2. 取回一條記錄

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

<?php
// 設(shè)置一個 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對象設(shè)置默認adapter
require_once 'Zend/Db/Table.php';
Zend_Db_Table::setDefaultAdapter($db);
// 連接到數(shù)據(jù)庫中的某一個表
class RoundTable extends Zend_Db_Table {}
$table = new RoundTable();
?>

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

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

3. 修改數(shù)據(jù)

修改行數(shù)據(jù)是一件很輕松的事情:只需要按照常規(guī)的方法修改類屬性.然后調(diào)用save()方法 就將改變的結(jié)果保存到了數(shù)據(jù)表中.

<?php
// 連接到數(shù)據(jù)庫中的表
class RoundTable extends Zend_Db_Table {}
$table = new RoundTable();
// 從表中取回的結(jié)果數(shù)據(jù)是一個Zend_Db_Table_Row對象
$row = $table->fetchRow('first_name = "Robin"');
//
// $row現(xiàn)在是一個帶有多種公有屬性的Zend_Db_Table_Row對象
// that map to table columns:
//
// $row->id = '3'
// $row->nobleTitle = 'Sir'
// $row->firstName = 'Robin'
// $row->favoriteColor = 'yellow'
//
// 改變favorite color字段,并且將變動存儲到數(shù)據(jù)表中.
$row->favoriteColor = 'blue';
$row->save();
?>

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

<?php
// 連接到數(shù)據(jù)庫中的表
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_Db_Table_Row如何在Zend Framework中使用了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI