昨天群里有人说使用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=''){}//详细显示一条记录
}
?>


    在这个模型里面,我是使用数组和数据库的字段来对应的。早期的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
  * @copyright http://www.phpobject.net/blog/
*/
class mysqlController
{
    var 
$module;
    
    function 
mysqlController(){
        require_once(
SITE_PATH.'/libs/module.class.php');
        
$this->module=new module('52site_siteinfo');//52site_siteinfo为表名称
        
$this->module->query("set names 'gb2312'");//如果是MYSQL5请加上这句
    
}
    
    function 
indexAction(){
        
print_r($this->module->select());//这样实现了读取数据
    
}
}
?>

     上面首先是控制器的构造函数里面,加入一个模型。然后在indexAction里面调用模型的方法来显示数据。这样就实现了最简单的查询列表。你可以通过这个地址来查看你的结果http://path/to/yoursite/mvc/index.php?controller=mysql&action=index
     以后我会写一个具体的demo来说明如何使用模型的其他方法,比如说查询、更新、增加、分页列表、多表连查等等。

     整个demo下载:

     
Tags: ,
评论(17) | 引用(704) | 阅读(9109)
ym0723 Says:
2008/03/24 23:47
下载不了
能否发份到我的邮箱
谢谢
myj2005 Says: Email
2007/12/16 14:58
我已经下载得了,谢谢
myj2005 Says: Email
2007/12/16 14:34
附件下载不了呀,能否发到我的邮箱:myj218@163.com
ihao Says:
2007/06/24 03:37
@feifengxlq:已经下载,非常感谢
ihao Says: Email
2007/06/23 08:47
@feifengxlq:你的blog里一直无法下载附件,上次来时以为是一时没有修正,今天再次来准备下载phpbean框架文章中关于模型,视图,单点入口这几个源文件来学习下(因为觉得对于个人使用zend确实太过庞大了,而你这个将mvc的基本结构说了,可以自己进一步扩充),可是还是无法下载(FF直接下载后保存的文件无法打开,用free down manage下载提示获取文件成功但与服务器失去连接),所以如果可以的话能否发一份到我的邮箱中,谢谢!
到http://www.yanxue8.com/index.php/u/15/下载吧,我发到噢这里了。
feifengxlq 回复于 2007/06/23 10:35
fdfviu Says: Email
2007/05/31 14:37
好像所有的"DEMO文件"都不能下載
far Says: Email
2007/05/28 17:00
下载不了啊,哪位仁兄发一份给我,谢了.
wybmzyb@163.com
www Says:
2007/05/17 17:10
zamjam99@yahoo.com.cn
正在找php .mvc 的东西,学习学习!!
有什么资料发给我!!!!
skyverd Says: Homepage
2007/04/28 19:05
PHP实现MVC开发得最简单的方法——视图及模版技术
PHP实现MVC开发得最简单的方法——单点入口

下载不了,能不能个我发份代码,谢谢
seawind_cao@163.com
啊哈 Says:
2007/04/26 18:44
博主你好,你提供的demo都无法下载.你能将<模型><单点入口>及<视图与模板>的demo发一份给我吗?
singkey@163.com 谢谢
分页: 1/73 第一页 1 2 3 4 5 6 7 8 9 10 下页 最后页
发表评论
昵称 [注册]
密码 游客无需密码
网址
电邮
打开HTML 打开UBB 打开表情 隐藏 记住我