使用MVC让程序多了很多数据库操作,使得性能下降,这着实让我吃了一惊。MVC只是一种框架,与数据库操作没有任何关系。MVC只是提供一种清晰的编程开发模式,只要你处理的好,是不可能多处很多无谓的数据库操作的。如果一个MVC让一个程序员在不知情的情况下多出了很多数据库操作就绝对不是一个很好的MVC架构。我觉得MVC只要提供一个简单的开发框架就行了,没有必要集成很多库类,库类最好能让程序员自己选择去使用。
我没有深入研究过MVC的理论,对我个人来说,模型就是一个数据库的封装,调用模型的方法,你可以得到相应的数据,但实现的细节程序员不需要关心。在实际开发中,很可能一个数据库的表就对应一个模型。
比如说一个用户信息表userinfo,对应就有一个模型user,通过调用模型user的add()方法你就可以向数据库添加一条数据,通过select()你就可以实现查询,通过update就能实现更新。同时模型应该是和具体的数据库类型无关的,无论你使用的mysql,oracle还是sql server。
同时我不推荐在WEB开发中使用ROR,复杂的多表查询使用SQL语言是多么方便和快捷的事情,而且性能更好。如果一个程序员连SQL的知识都没有,我不认为他是一个合格的程序员。所以,我在我的模型里面,提供了一个query的方法来实现直接的SQL查询。
下面是PHP开发MVC模型的一个大概结果。不是完整代码,完整代码请见demo包。
<ol class="dp-xml"><li class="alt"><span><span class="tag"><</span><span> ? </span></span></li><li><span>class module{ </span></li><li class="alt"><span>var $mysql;//数据库操作类,<br />可以是mysql,oracle,sql等等 </span></li><li><span>var $tbname;//模型对应的表名称 </span></li><li class="alt"><span>var $</span><span class="attribute">debug</span><span>=</span><span class="attribute-value">false</span><span>;//是否是调试模式 </span></li><li><span>function module($tbname,$</span><span class="attribute">db</span><span>=</span><span class="attribute-value">''</span><span>){}<br />//构造函数 </span></li><li class="alt"><span>function _setDebug($</span><span class="attribute">debug</span><span>=</span><span class="attribute-value">true</span><span>){}</span></li><li class="alt"><span>//开启或者关闭调试模式 </span></li><li><span>function add($row,$</span><span class="attribute">tbname</span><span>=</span><span class="attribute-value">''</span><span>){}</span></li><li><span>//新增加一条记录 </span></li><li class="alt"><span>function query($strsql){}//直接查询sql语句 </span></li><li><span>function count($</span><span class="attribute">where</span><span>=</span><span class="attribute-value">''</span><span>,$</span><span class="attribute">tbname</span><span>=</span><span class="attribute-value">''</span><span>){ }</span></li><li><span>//计数统计 </span></li><li class="alt"><span>function select($</span><span class="attribute">where</span><span>=</span><span class="attribute-value">''</span><span>,$</span><span class="attribute">tbname</span><span>=</span><span class="attribute-value">''</span><span>){}</span></li><li class="alt"><span>//查询 </span></li><li><span>function delete($</span><span class="attribute">where</span><span>=</span><span class="attribute-value">''</span><span>,$</span><span class="attribute">tbname</span><span>=</span><span class="attribute-value">''</span><span>){}</span></li><li><span>//删除满足条件的一个记录 </span></li><li class="alt"><span>function update($set,$where,$</span><span class="attribute">tbname</span><span>=</span><span class="attribute-value">''</span><span>){}</span></li><li class="alt"><span>//更新指定记录 </span></li><li><span>function detail($where,$</span><span class="attribute">tbname</span><span>=</span><span class="attribute-value">''</span><span>){}</span></li><li><span>//详细显示一条记录 </span></li><li class="alt"><span>} </span></li><li><span class="tag">?></span><span> </span></span></li></ol>
在这个模型里面,我是使用数组和数据库的字段来对应的。早期的PHPBEAN里面使用了对象来对应。但后来感觉这种PHP开发MVC模型的方法在PHP中不好,而且增加了很多无谓的类。使用数组更加方便,效果更好(PHP中的数组的确是个好东西,相对JAVA来说好太多了)。
在下面的demo中,我使用了mysql数据库来演示,其中数据库操作类改自我原来的一个库类。
下面,详细讲解使用demo。^_^
在原来的的包的index.php里面增加
<ol class="dp-xml"> <li class="alt"><span><span class="tag"><</span><span> ? </span></span></li><li><span>require_once(SITE_PATH.'/<br />libs/phpbean.class.php'); </span></li><li class="alt"><span>require_once(SITE_PATH.'/<br />libs/mysql.class.php'); </span></li><li><span>$</span><span class="attribute">phpbean</span><span>=</span><span class="attribute-value">new</span><span> phpbean(); </span></li><li class="alt"><span>global $phpbean; </span></li><li><span>$</span><span class="attribute">mysql</span><span>=</span><span class="attribute-value">new</span><span> mysql("localhost"<br />,"****","****","52site"); </span></li><li class="alt"><span>$phpbean-</span><span class="tag">></span><span>register('db',$mysql); </span></span></li> <li><span>unset($mysql); </span></li> <li class="alt"> <span class="tag">?></span><span> </span> </li> </ol>
这段PHP开发MVC模型代码主要是把MYSQL注册到注册器里面,关于注册器的使用的原理,可以看我翻译的两篇文章。
然后新建一个mysqlController.class.php文件,代码如下:
<ol class="dp-xml"> <li class="alt"><span><span class="tag"><</span><span> ? </span></span></li><li><span>/** </span></li><li class="alt"><span>* MVC演示demo </span></li><li><span>* 仅仅实现最基本的MVC功能,不包含安全处理<br />,数据过滤,及其他优化措施。 </span></li><li class="alt"><span>* @author:feifengxlq </span></li><li><span>* @since:2007-1-24 </span></li><li class="alt"><span>* @copyright http://www.phpobject.net/blog/ </span></li><li><span>*/ </span></li><li class="alt"><span>class mysqlController </span></li><li><span>{ </span></li><li class="alt"><span>var $module; </span></li><li><span>function mysqlController(){ </span></li><li class="alt"><span>require_once(SITE_PATH.'/libs/module.class.php'); </span></li><li><span>$this-</span><span class="tag">></span><span class="attribute">module</span><span>=</span><span class="attribute-value">new</span><span> module('52site_siteinfo');<br>//52site_siteinfo为表名称 </span></span></li> <li class="alt"> <span>$this-</span><span class="tag">></span><span>module-</span><span class="tag">></span><span>query("set names 'gb2312'");<br>//如果是MYSQL5请加上这句 </span> </li> <li><span>} </span></li> <li class="alt"><span>function indexAction(){ </span></li> <li> <span>print_r($this-</span><span class="tag">></span><span>module-</span><span class="tag">></span><span>select());//这样实现了读取数据 </span> </li> <li class="alt"><span>} </span></li> <li><span>} </span></li> <li class="alt"> <span class="tag">?></span><span> </span> </li> </ol>
上面首先是控制器的构造函数里面,加入一个模型。然后在indexAction里面调用模型的方法来显示数据。这样就实现了最简单的查询列表。
以后我会写一个具体的demo来说明如何使用PHP开发MVC模型的其他方法,比如说查询、更新、增加、分页列表、多表连查等等。