您好,登錄后才能下訂單哦!
這期內容當中小編將會給大家帶來有關Zend_Db_Table_Row如何在Zend Framework中使用,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
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_Db_Table_Row如何在Zend Framework中使用了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。