码迷,mamicode.com
首页 > Web开发 > 详细

cakephp 的query方法,直接写在controller中是否 有点不合适

时间:2015-06-10 11:52:45      阅读:113      评论:0      收藏:0      [点我收藏+]

标签:

模型的query()函数有时是非常实用的,它可以在任何需要数据的地方执行SQL语句.
但不是在什么地方调用query()方法都是恰当的.特别是在控制器中直接调用模型的query()方法

技术分享$this->MyModel->query(‘Here comes the SQL statement‘);

在控制器中调用模型的query方法么有什么不可以,但它引入了数据库相关的代码,这违反了MVC模式的原则

一个更加干净的方案是把SQL语句移动到模型中,因此上面那段代码重构为:

技术分享// 在模型中
技术分享function doSomething() {
技术分享    $this->query(‘Here comes the SQL statement‘);
技术分享}
技术分享// i在控制器中
技术分享$this->MyModel->doSomething();

不要在控制器中加入数据库相关的代码,这些代码都应该放置在模型中,有模型去处理

这个方案需要编写更多的代码,但是它带来了一些优点:

    * 易于测试
    * 更可读
    * 避免了查询代码在多个控制器之间导出复制,使代码更简洁

cakephp 的query方法,直接写在controller中是否 有点不合适

标签:

原文地址:http://www.cnblogs.com/oxspirt/p/4565433.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!