PHP实现MVC开发得最简单的方法——模型
前端之家收集整理的这篇文章主要介绍了
PHP实现MVC开发得最简单的方法——模型,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
昨天群里有人说使用MVC让程序多了很多数据库操作,使得性能下降,这着实让我吃了一惊。MVC只是一种框架,与数据库操作没有任何关系。MVC只是提供一种清晰的编程开发模式,只要你处理的好,是不可能多处很多无谓的数据库操作的。如果一个MVC让一个程序员在不知情的情况下多出了很多数据库操作就绝对不是一个很好的MVC架构。我觉得MVC只要提供一个简单的开发框架就行了,没有必要集成很多库类,库类最好能让程序员自己选择去使用。
我自己这个MVC框架的目的就只是实现一个简单的MVC流程,其他的大家具体情况具体添加。做到真正的小巧、灵活、高效!
前几周我写了两篇文章,《PHP实现MVC开发得最简单的方法——视图及模版技术》、《PHP实现MVC开发得最简单的方法——单点入口》。今天具体说说如何实现MVC的模型。
我没有深入研究过MVC的理论,对我个人来说,模型就是一个数据库的封装,调用模型的方法,你可以得到相应的数据,但实现的细节程序员不需要关心。在实际开发中,很可能一个数据库的表就对应一个模型。比如说一个用户信息表userinfo,对应就有一个模型user,通过调用模型user的add()方法你就可以向数据库添加一条数据,通过select()你就可以实现查询,通过update就能实现更新。同时模型应该是和具体的数据库类型无关的,无论你使用的MysqL,oracle还是sqlserver。同时我不推荐在WEB开发中使用ROR,复杂的多表查询使用sql语言是多么方便和快捷的事情,而且性能更好。如果一个程序员连sql的知识都没有,我不认为他是一个合格的程序员。所以,我在我的模型里面,提供了一个query的方法来实现直接的SQL查询。
下面是模型的一个大概结果。不是完整代码,完整代码请见demo包。 <div class="codetitle"><a style="CURSOR: pointer" data="52389" class="copybut" id="copybut52389" onclick="doCopy('code52389')"> 代码如下:
<div class="codebody" id="code52389">
<?
classmodule{ var$
MysqL;//
数据库操作类,可以是
MysqL,oracle,
sql等等 var$tbname;//模型对应的表
名称 var$debug=false;//是否是调试模式 functionmodule($tbname,$db=''){}//构造
函数 function_setDebug($debug=true){}//开启或者
关闭调试模式 functionadd($row,$tbname=''){}//新
增加一条记录 functionquery($str
sql){}//直接
查询sql语句 functioncount($where='',$tbname=''){}//计数
统计 functionselect($where='',$tbname=''){}//
查询 functiondelete($where='',$tbname=''){}//
删除满足条件的一个记录 functionupdate($set,$where,$tbname=''){}//更新指定记录 functiondetail($where,$tbname=''){}//详细
显示一条记录
}
?>
在这个模型里面,我是使用数组和
数据库的字段来对应的。早期的
PHPBEAN里面使用了对象来对应。但后来感觉这种
方法在
PHP中不好,而且
增加了很多无谓的类。使用数组更加方便,
效果更好(
PHP中的数组的确是个好东西,相对JAVA来说好太多了)。 在下面的demo中,我使用了
MysqL数据库来演示,其中
数据库操作类改自我原来的一个库类,详细请看《
修改下以前的库类,
PHP5->
PHP4》。 下面,详细讲解使用demo。^_^
在原来的的包的index.
PHP里面
增加 <?
require_once(SITE_PATH.'/libs/
PHPbean.class.
PHP');
require_once(SITE_PATH.'/libs/
MysqL.class.
PHP');
$
PHPbean=new
PHPbean();
global$
PHPbean; $
MysqL=new
MysqL("localhost","
**","52site");
$PHPbean->register('db',$MysqL);
unset($MysqL);
?> 这段代码主要是把MysqL注册到注册器里面,关于注册器的使用的原理,可以看我翻译的两篇文章。
然后新建一个MysqLController.class.PHP文件,代码如下: <?
/ MVC演示demo
仅仅实现最基本的MVC
功能,不包含安全处理,数据过滤,及其他优化措施。
@author:feifengxlq
@since:2007-1-24
@copyrighthttp://www.PHPobject.net/blog/
/
class
MysqLController
{
var$module; function
MysqLController(){
require_once(SITE_PATH.'/libs/module.class.
PHP');
$this->module=newmodule('52site_siteinfo');//52site_siteinfo为表
名称 $this->module->query("setnames'gb2312'");//如果是
MysqL5请
加上这句
} functionindexAction(){
print_r($this->module->select());//这样实现了读取数据
}
}
?> 上面首先是控制器的构造
函数里面,加入一个模型。然后在indexAction里面
调用模型的
方法来
显示数据。这样就实现了最简单的
查询列表。你可以通过这个地址来查看你的结果http://path/to/yoursite/mv...
以后我会写一个具体的demo来说明如何使用模型的其他
方法,比如说
查询、更新、
增加、
分页列表、多表连查等等。