Zend Framework教程之Zend_Db_Table_Row用法實(shí)例分析
本文實(shí)例講述了Zend Framework教程之Zend_Db_Table_Row用法。分享給大家供大家參考,具體如下:
1. 簡(jiǎn)介
Zend_Db_Table_Row是Zend Framework的行數(shù)據(jù)網(wǎng)關(guān).通常來(lái)說(shuō),你不可以自己實(shí)例化Zend_Db_Table_Row, 而是通過(guò)調(diào)用Zend_Db_Table::find()方法或者Zend_Db_Table::fetchRow()方法將Zend_Db_Table_Row作為 結(jié)果數(shù)據(jù)返回過(guò)來(lái).一旦你得到來(lái)一個(gè)Zend_Db_Table_Row對(duì)象,你可以修改記錄值(體現(xiàn)為類的屬性)然后 調(diào)用save()方法可以將更改保存到原表上.
2. 取回一條記錄
首先,需要實(shí)例化一個(gè)Zend_Db_Table類.
<?php // 設(shè)置一個(gè) 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對(duì)象設(shè)置默認(rèn)adapter require_once 'Zend/Db/Table.php'; Zend_Db_Table::setDefaultAdapter($db); // 連接到數(shù)據(jù)庫(kù)中的某一個(gè)表 class RoundTable extends Zend_Db_Table {} $table = new RoundTable(); ?>
接下來(lái),使用Zend_Db_Table::find()方法和主鍵進(jìn)行查詢,或者使 用Zend_Db_Table::fetchRow()方法查詢.
得到的返回結(jié)果是一個(gè)Zend_Db_Table_Row 對(duì)象,該對(duì)象的屬性名采用camelCaps的形式對(duì)應(yīng)數(shù)據(jù)庫(kù)中帶下劃線的表名.
如,表名 若為first_name,那么類中的改屬性則為firstName.
<?php // 從表中取回的結(jié)果數(shù)據(jù)是一個(gè)Zend_Db_Table_Row對(duì)象 $row = $table->fetchRow('first_name = "Robin"'); // // $row現(xiàn)在是一個(gè)帶有多種公有屬性的Zend_Db_Table_Row對(duì)象 // 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ù)庫(kù)中的表 class RoundTable extends Zend_Db_Table {} $table = new RoundTable(); // 從表中取回的結(jié)果數(shù)據(jù)是一個(gè)Zend_Db_Table_Row對(duì)象 $row = $table->fetchRow('first_name = "Robin"'); // // $row現(xiàn)在是一個(gè)帶有多種公有屬性的Zend_Db_Table_Row對(duì)象 // that map to table columns: // // $row->id = '3' // $row->nobleTitle = 'Sir' // $row->firstName = 'Robin' // $row->favoriteColor = 'yellow' // // 改變favorite color字段,并且將變動(dòng)存儲(chǔ)到數(shù)據(jù)表中. $row->favoriteColor = 'blue'; $row->save(); ?>
但是,你不能夠修改主鍵的值.假如你試圖進(jìn)行改操作, Zend_Db_Table_Row將拋出一個(gè)異常.
<?php // 連接到數(shù)據(jù)庫(kù)中的表 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è)計(jì)入門教程》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家基于Zend Framework框架的PHP程序設(shè)計(jì)有所幫助。
- Zend Framework教程之Zend_Db_Table表關(guān)聯(lián)實(shí)例詳解
- Zend Framework框架教程之Zend_Db_Table_Rowset用法實(shí)例分析
- Zend Framework教程之Zend_Db_Table用法詳解
- ZendFramework框架實(shí)現(xiàn)連接兩個(gè)或多個(gè)數(shù)據(jù)庫(kù)的方法
- Zend Framework教程之連接數(shù)據(jù)庫(kù)并執(zhí)行增刪查的方法(附demo源碼下載)
- Zend Framework連接Mysql數(shù)據(jù)庫(kù)實(shí)例分析
- 解析如何使用Zend Framework 連接數(shù)據(jù)庫(kù)
- zend framework配置操作數(shù)據(jù)庫(kù)實(shí)例分析
- Zend Framework入門教程之Zend_Db數(shù)據(jù)庫(kù)操作詳解
相關(guān)文章
PHP通用分頁(yè)類page.php[仿google分頁(yè)]
PHP通用分頁(yè)類。本代碼是用于分頁(yè)用的,稍做修改可用于各種程序。 使用方式請(qǐng)參考本人文章。2008-08-08php腳本運(yùn)行時(shí)的超時(shí)機(jī)制詳解
在我們平常的開發(fā)中,也許曾經(jīng)都遇到過(guò)PHP腳本運(yùn)行超時(shí)的情況,當(dāng)遇到這種情況我們經(jīng)常會(huì)通過(guò)使用 set_time_limit(非安全模式),或修改配置文件并重啟服務(wù)器,或者修改程序減少程序的執(zhí)行時(shí)間,使其在允許的范圍之內(nèi),以解決此問(wèn)題。2016-02-02Yii1.1中通過(guò)Sql查詢進(jìn)行的分頁(yè)操作方法
這篇文章主要介紹了Yii1.1中通過(guò)Sql查詢進(jìn)行的分頁(yè)操作方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-03-03thinkPHP簡(jiǎn)單調(diào)用函數(shù)與類庫(kù)的方法
這篇文章主要介紹了thinkPHP簡(jiǎn)單調(diào)用函數(shù)與類庫(kù)的方法,簡(jiǎn)單講述了thinkPHP公共函數(shù)庫(kù)的文件位置并結(jié)合實(shí)例分析了類庫(kù)的調(diào)用方法,需要的朋友可以參考下2017-03-03詳解Laravel5.6通過(guò)路由進(jìn)行API版本控制的簡(jiǎn)單方法
這篇文章主要介紹了詳解Laravel5.6通過(guò)路由進(jìn)行API版本控制的簡(jiǎn)單方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01PHP仿qq空間或朋友圈發(fā)布動(dòng)態(tài)、評(píng)論動(dòng)態(tài)、回復(fù)評(píng)論、刪除動(dòng)態(tài)或評(píng)論的功能(上)
我們大部分人都發(fā)過(guò)動(dòng)態(tài),想必都知道發(fā)動(dòng)態(tài)、回復(fù)評(píng)論、刪除動(dòng)態(tài)的整個(gè)過(guò)程,那么這個(gè)功能是如何實(shí)現(xiàn)的呢?下面小編給大家?guī)?lái)了實(shí)例代碼,對(duì)PHP仿qq空間或朋友圈發(fā)布動(dòng)態(tài)、評(píng)論動(dòng)態(tài)、回復(fù)評(píng)論、刪除動(dòng)態(tài)或評(píng)論的功能感興趣的朋友,一起學(xué)習(xí)吧2017-05-05常見的5個(gè)PHP編碼小陋習(xí)以及優(yōu)化實(shí)例講解
這篇文章主要介紹了常見的5個(gè)PHP編碼小陋習(xí)實(shí)例講解,講解了常見寫法和優(yōu)化方法,看一下是否自己也是這樣寫的呢2021-02-02