Zend Framework教程之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(); } ?>
更多关于zend相关内容感兴趣的读者可查看本站专题:《zend framework框架入门教程》、《php优秀开发框架总结》、《yii框架入门及常用技巧总结》、《thinkphp入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于zend framework框架的php程序设计有所帮助。
推荐阅读
-
Zend Framework教程之Zend_Db_Table_Row用法实例分析
-
Zend Framework教程之资源(Resources)用法实例详解
-
Zend Framework教程之Application用法实例详解
-
Zend Framework教程之Resource Autoloading用法实例
-
Zend Framework教程之MVC框架的Controller用法分析
-
Zend Framework动作助手Json用法实例分析
-
Zend Framework教程之模型Model用法简单实例
-
Zend Framework框架教程之Zend_Db_Table_Rowset用法实例分析_php实例
-
Zend Framework教程之Application用法实例详解_php实例
-
Zend Framework教程之资源(Resources)用法实例详解,zendframework_PHP教程