cakephp: 你应该在控制器中调用Model::query()方法吗?
2013-03-22 09:14
281 查看
模型的query()函数有时是非常实用的,它可以在任何需要数据的地方执行SQL语句.
但不是在什么地方调用query()方法都是恰当的.特别是在控制器中直接调用模型的query()方法
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
$this->MyModel->query('Here comes the SQL statement');
在控制器中调用模型的query方法么有什么不可以,但它引入了数据库相关的代码,这违反了MVC模式的原则
一个更加干净的方案是把SQL语句移动到模型中,因此上面那段代码重构为:
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
// 在模型中
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
function doSomething() {
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
$this->query('Here comes the SQL statement');
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
}
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
// i在控制器中
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
$this->MyModel->doSomething();
不要在控制器中加入数据库相关的代码,这些代码都应该放置在模型中,有模型去处理
这个方案需要编写更多的代码,但是它带来了一些优点:
* 易于测试
* 更可读
* 避免了查询代码在多个控制器之间导出复制,使代码更简洁
但不是在什么地方调用query()方法都是恰当的.特别是在控制器中直接调用模型的query()方法
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
$this->MyModel->query('Here comes the SQL statement');
在控制器中调用模型的query方法么有什么不可以,但它引入了数据库相关的代码,这违反了MVC模式的原则
一个更加干净的方案是把SQL语句移动到模型中,因此上面那段代码重构为:
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
// 在模型中
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
function doSomething() {
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
$this->query('Here comes the SQL statement');
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
}
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
// i在控制器中
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
$this->MyModel->doSomething();
不要在控制器中加入数据库相关的代码,这些代码都应该放置在模型中,有模型去处理
这个方案需要编写更多的代码,但是它带来了一些优点:
* 易于测试
* 更可读
* 避免了查询代码在多个控制器之间导出复制,使代码更简洁
相关文章推荐
- cakephp: 你应该在控制器中调用Model::query()方法吗?
- Laravel控制器调用model的两种方法
- YII 如何在控制器里调用 model 方法
- ThinkPHP框架----控制器调用模型里的方法,一直报错——Think\Model:..方法不存在!
- YII 如何在控制器里调用 model 方法
- 控制器之间的通信(传值方法)以及多次调用通信
- 视图调用控制器的方法
- 关于Spring JdbcTemplate调用queryForObject()方法结果集为空时报异常的解决办法
- close()方法应该在finally语句中调用吗?
- thinkphp——通过跨控制器调用方法
- ThinkPHP跨控制器调用方法
- 使用jQuery异步传递Model到控制器方法,并异步返回错误信息
- MVC5 您不能调用控制器“xx”上的操作方法“xx”,因为该方法是一种泛型方法
- 循环中调用DAO时解决方案。(数据量比较大时应该采用的方法。)
- 夸模块、控制器调用方法
- 找到多个与名为“HOME”的控制器匹配的类型。如果为此请求(“{CONTROLLER}/{ACTION}/{ID}”)提供服务的路由在搜索匹配此请求的控制器时没有指定命名空间,则会发生此情况。如果是这样,请通过调用含有“NAMESPACES”参数的“MAPROUTE”方法的重载来注册此路由。
- MVC 从控制器跳转到视图的方法 |Model传值
- thinkphp3.2跨控制器调用其他模块的方法
- orm 通用方法——QueryModelCount条件查询记录数
- 普元 ESB 6.6,在开发的中介流中需要使用queryByNamedSql方法,这个方法对应的namedSql文件应该放在什么位置下?