本文實例講述了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作為結(jié)果資料回傳過來.一旦你得到來一個Zend_Db_Table_Row物件,你可以修改記錄值(體現(xiàn)為類別的屬性)然後呼叫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è)置默認(rèn)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_TablefetchetchRow()::fetch得到的回傳結(jié)果是一個Zend_Db_Table_Row 物件,該物件的屬性名稱採用camelCaps的形式對應(yīng)資料庫中帶下劃線的表名.
如,表名若為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 .修改資料修改行資料是一件很輕鬆的事情:只需要按照常規(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 Framework框架的PHP程式設(shè)計有所幫助。 更多Zend Framework教程之Zend_Db_Table_Row用法實例分析相關(guān)文章請關(guān)注PHP中文網(wǎng)!
本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool
免費脫衣圖片

Undresser.AI Undress
人工智慧驅(qū)動的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章
指南:恆星刀片保存文件位置/保存文件丟失/不保存
4 週前
By DDD
Oguri Cap Build Guide |漂亮的德比志
2 週前
By Jack chen
Agnes Tachyon Build Guide |漂亮的德比志
2 週前
By Jack chen
沙丘:覺醒 - 高級行星學(xué)家Quest演練
4 週前
By Jack chen
約會一切:德克和哈珀關(guān)係指南
4 週前
By Jack chen

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6
視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)
