Zend Framework教程之Zend_Db_Table_Row用法实例分析
发布:smiling 来源: PHP粉丝网 添加日期:2021-07-20 21:08:36 浏览: 评论:0
这篇文章主要介绍了Zend Framework教程之Zend_Db_Table_Row用法,详细讲述了Zend_Db_Table_Row的功能,并结合实例形式详细分析了Zend_Db_Table_Row操作数据的相关技巧,需要的朋友可以参考下。
本文实例讲述了Zend Framework教程之Zend_Db_Table_Row用法,分享给大家供大家参考,具体如下:
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();
- }
- ?>
Tags: Framework Zend_Db_Table_Row
相关文章
- ·zend framework 实例(2013-11-14)
- ·Zend Framework 配置与应用(2013-11-14)
- ·zend framework Invalid command RewriteEngine(2014-08-04)
- ·Zend Framework页面缓存实例(2021-03-02)
- ·zend framework框架中url大小写问题解决方法(2021-04-03)
- ·Zend Framework+smarty用法实例详解(2021-07-18)
- ·Zend Framework连接Mysql数据库实例分析(2021-07-18)
- ·Zend Framework缓存Cache用法简单实例(2021-07-18)
- ·Zend Framework入门知识点小结(2021-07-18)
- ·Zend Framework教程之Zend_Db_Table用法详解(2021-07-18)
- ·Zend Framework框架教程之Zend_Db_Table_Rowset用法实例分析(2021-07-20)
- ·Zend Framework实现多文件上传功能实例(2021-07-20)
- ·Zend Framework教程之Zend_Form组件实现表单提交并显示错误提示的方法(2021-07-20)
- ·Zend Framework分页类用法详解(2021-07-20)
- ·Zend Framework实现将session存储在memcache中的方法(2021-07-20)
- ·Zend Framework框架路由机制代码分析(2021-07-20)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)