《PHP教程:Zend Framework教程之Zend_Db_Table_Row用法實例分析》要點:
本文介紹了PHP教程:Zend Framework教程之Zend_Db_Table_Row用法實例分析,希望對您有用。如果有疑問,可以聯(lián)系我們。
本文實例講述了Zend Framework教程之Zend_Db_Table_Row用法.分享給大家供大家參考,具體如下:PHP實戰(zhàn)
1. 簡介PHP實戰(zhàn)
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()辦法可以將更改保存到原表上.PHP實戰(zhàn)
2. 取回一條記錄PHP實戰(zhàn)
首先,需要實例化一個Zend_Db_Table類.PHP實戰(zhàn)
<?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_Table::fetchRow()辦法查詢.
得到的返回結(jié)果是一個Zend_Db_Table_Row 對象,該對象的屬性名采用camelCaps的形式對應(yīng)數(shù)據(jù)庫中帶下劃線的表名.
如,表名 若為first_name,那么類中的改屬性則為firstName.PHP實戰(zhàn)
<?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ù)PHP實戰(zhàn)
修改行數(shù)據(jù)是一件很輕松的事情:只需要依照常規(guī)的方法修改類屬性.然后調(diào)用save()方法 就將改變的結(jié)果保存到了數(shù)據(jù)表中.PHP實戰(zhàn)
<?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實戰(zhàn)
<?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(); } ?>
更多關(guān)于zend相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Zend FrameWork框架入門教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《Yii框架入門及常用技巧總結(jié)》、《ThinkPHP入門教程》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》PHP實戰(zhàn)
希望本文所述對大家基于Zend Framework框架的PHP程序設(shè)計有所贊助.PHP實戰(zhàn)
維易PHP培訓(xùn)學(xué)院每天發(fā)布《PHP教程:Zend Framework教程之Zend_Db_Table_Row用法實例分析》等實戰(zhàn)技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培養(yǎng)人才。
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/7287.html