您的位置:首页 > 产品设计 > UI/UE

cakephp: 你应该在控制器中调用Model::query()方法吗?

2013-03-22 09:14 281 查看
模型的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();

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

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

    * 易于测试

    * 更可读

    * 避免了查询代码在多个控制器之间导出复制,使代码更简洁
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  php
相关文章推荐