在数据库中使用对象的好处

我们都知道如何从数据库中获取我们需要的行(记录),读取数据,然后存取一些改动。很明显也很直接,在这个过程背后也没有什么拐弯抹角的。然而对于我们使用面对对象的程序设计(OOP)来管理我们数据库中的数据时,这个过程就需要大大改进一下了。这篇文章将对如何设计一个面对对象的方式来管理数据库的记录做一个简单的描述。你的数据当中的所有内部逻辑关系将被封装到一个非常条理的记录对象,这个对象能够提供专门(专一)的确认代码系统,转化以及数据处理。随着Zend Engine2 和PHP5的发布,PHP开发者将会拥有更强大的面对对象的工具来辅助工作,这将使这个过程(面对对象地管理数据库)更有吸引力。

成都创新互联坚实的技术研发基础赢得了行业内的良好口碑,公司成立10余年来,为上千家企业提供过网站建设、软件开发、搜索引擎优化技术、互联网大数据整合营销服务,多年的技术服务成功经验、众多的客户使我们能懂得更多,做得更好。"让您的网站跑起来"是我们一直追求的目标!

以下列出了一些使用对象来描叙你的数据库的有利方面:

1、存取方法(Accessor methods)将会使你对属性的读取和写入过程做到完全的控制

2、每一级的每个记录和属性(的操作)都有确认过程

3、从关系表中智能的获取对象

4、重复使用的逻辑方法意味着所有的数据交互都要通过相同的基础代码(codebase),这将使维护变得更加简单

5、代码简单,因为不同的记录的内部逻辑都已经包含在各自所处的类(class)当中,而不是繁琐的库(lib)文件

6、在手工编写代码和SQL查询语句时,出错的机会将更少

存取方法(Accessor methods)

存取方式是通过类给实例(instance)的变量赋值。一个例子,我有一个叫User的类,并且有一个实例$username,我会写这样的存取方法(函数),User->username()和User->setUsername()用来返回和给实例赋值。

class User {

var $username;

function username() {

return $this->username;

}

function setUsername($newUsername) {

$this->username = $newUsername;

}

}

?>

这里有很好的理由让我们编写这样的“特别的代码”。它将使开发者更灵活的改变类的繁琐的工作,因为这一过程将不需要其他的使用类的php代码。让我们来看看下面这个更加完善的可信赖的User类。

变量$username将不复存在,所有的东西都被整合的放在数组$_data当中

如果username是空的话,username()函数将提供一个缺省(默认)的值给它

setUsername()过程将在接受值之前确认username是否合乎标准格式(如字长等)

class User {

var $_data = array(); // associative array containing all the attributes for the User

function username() {

return !empty($this->_data['username']) ? $this->_data['username'] : '(no name!)';

}

function setUsername($newUsername) {

if ($this->validateUsername($newUsername)) {

$this->_data['username'] = $newUsername;

}

}

function validateUsername(&$someName) {

if (strlen($someName) > 12) {

throw new Exception('Your username is too long

关于在数据库中使用对象的好处就为大家总结这么多, 相信大家通过上文的学习,对在数据库中使用对象的好处有所了解,大家可以在以后的工作中在数据库中使用对象,相信这样会给大家的工作带来很多的便利,最后,希望大家都能够从上文中涉及到的内容中有所收获。

本文题目:在数据库中使用对象的好处
网站链接:http://www.mswzjz.cn/qtweb/news38/227988.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能