找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1525|回复: 0
打印 上一主题 下一主题

PHP实现MVC开发得最简单的方法——模型

[复制链接]

3444

主题

3465

帖子

1万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
11142
跳转到指定楼层
楼主
发表于 2018-2-14 09:25:02 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            昨天群里有人说使用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包。  
[U]复制代码[/U] 代码如下:
   

    在这个模型里面,我是使用数组和数据库的字段来对应的。早期的PHPBEAN里面使用了对象来对应。但后来感觉这种方法在PHP中不好,而且增加了很多无谓的类。使用数组更加方便,效果更好(PHP中的数组的确是个好东西,相对JAVA来说好太多了)。  
    在下面的demo中,我使用了mysql数据库来演示,其中数据库操作类改自我原来的一个库类,详细请看《修改下以前的库类,php5->php4》。  
    下面,详细讲解使用demo。^_^  
     在原来的的包的index.php里面增加  
register('db',$mysql);   
unset($mysql);   
?>   
   这段代码主要是把MYSQL注册到注册器里面,关于注册器的使用的原理,可以看我翻译的两篇文章。  
然后新建一个mysqlController.class.php文件,代码如下:  
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/mv...  
     以后我会写一个具体的demo来说明如何使用模型的其他方法,比如说查询、更新、增加、分页列表、多表连查等等。
            
            
您可能感兴趣的文章:
  • 最新的php 文件上传模型,支持多文件上传
  • ThinkPHP关联模型操作实例分析
  • ThinkPHP实例化模型的四种方法概述
  • PHP开发框架Laravel数据库操作方法总结
  • thinkphp视图模型查询提示ERR: 1146:Table ''db.pr_order_view'' doesn''t exist的解决方法
  • 实现PHP框架系列文章(6)mysql数据库方法
  • PHP的Yii框架中使用数据库的配置和SQL操作实例教程
  • PHP的Laravel框架结合MySQL与Redis数据库的使用部署
  • ThinkPHP框架分布式数据库连接方法详解
  • 自制PHP框架之模型与数据库
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端