昨天群里有人说使用MVC让程序多了很多数据库操作,使得性能下降,这着实让我吃了一惊。MVC只是一种框架,与数据库操作没有任何关系。MVC只是提供一种清晰的编程开发模式,只要你处理的好,是不可能多处很多无谓的数据库操作的。如果一个MVC让一个程序员在不知情的情况下多出了很多数据库操作就绝对不是一个很好的MVC架构。我觉得MVC只要提供一个简单的开发框架就行了,没有必要集成很多库类,库类最好能让程序员自己选择去使用。
我自己这个MVC框架的目的就只是实现一个简单的MVC流程,其他的大家具体情况具体添加。做到真正的小巧、灵活、高效!
前几周我写了两篇文章,《PHP实现MVC开发得最简单的方法——视图及模版技术》、《PHP实现MVC开发得最简单的方法——单点入口》。今天具体说说如何实现MVC的模型。
我没有深入研究过MVC的理论,对我个人来说,模型就是一个数据库的封装,调用模型的方法,你可以得到相应的数据,但实现的细节程序员不需要关心。在实际开发中,很可能一个数据库的表就对应一个模型。比如说一个用户信息表userinfo,对应就有一个模型user,通过调用模型user的add()方法你就可以向数据库添加一条数据,通过select()你就可以实现查询,通过update就能实现更新。同时模型应该是和具体的数据库类型无关的,无论你使用的mysql,oracle还是sql server。同时我不推荐在WEB开发中使用ROR,复杂的多表查询使用SQL语言是多么方便和快捷的事情,而且性能更好。如果一个程序员连SQL的知识都没有,我不认为他是一个合格的程序员。所以,我在我的模型里面,提供了一个query的方法来实现直接的SQL查询。
下面是模型的一个大概结果。不是完整代码,完整代码请见demo包。
复制代码 代码如下:
class module{
var $mysql;//数据库操作类,可以是mysql,oracle,sql等等
var $tbname;//模型对应的表名称
var $debug=false;//是否是调试模式
function module($tbname,$db=''){}//构造函数
function _setDebug($debug=true){}//开启或者关闭调试模式
function add($row,$tbname=''){}//新增加一条记录
function query($strsql){}//直接查询sql语句
function count($where='',$tbname=''){ }//计数统计
function select($where='',$tbname=''){}//查询
function delete($where='',$tbname=''){}//删除满足条件的一个记录
function update($set,$where,$tbname=''){}//更新指定记录
function detail($where,$tbname=''){}//详细显示一条记录
}
?>