cakephp: 你应该在控制器中调用Model::query()方法吗?
2007-06-04 22:24
267 查看
模型的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();
不要在控制器中加入数据库相关的代码,这些代码都应该放置在模型中,有模型去处理
这个方案需要编写更多的代码,但是它带来了一些优点:
* 易于测试
* 更可读
* 避免了查询代码在多个控制器之间导出复制,使代码更简洁
但不是在什么地方调用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: 你应该在控制器中调用Model::query()方法吗?
- ThinkPHP框架----控制器调用模型里的方法,一直报错——Think\Model:..方法不存在!
- Laravel控制器调用model的两种方法
- YII 如何在控制器里调用 model 方法
- YII 如何在控制器里调用 model 方法
- 使用jQuery异步传递Model到控制器方法,并异步返回错误信息
- YII2调用当前控制器方法
- RailsCasts中文版,#4 Move Find into Model 将查询方法从控制器上移至模型
- 视图调用控制器的方法
- ios 不通过import 调用其他控制器的方法
- iOS中控制器的11中生命周期的调用方法以及使用
- Laravel5.1数据库连接、创建数据库、创建model及创建控制器的方法
- Laravel5.1数据库连接、创建数据库、创建model及创建控制器的方法
- SpringMVC几个核心类(控制器核心类,加载配置文件核心类,处理url影射核心类,处理视图资源核心类,方法动态调用核心类)
- thinkphp5的控制器调用自身模块和调用其他模块的方法
- ThinkPHP控制器间实现相互调用的方法
- Shiro,多个角色调用控制器里面方法
- Caliburn框架中二级Menu无法调用ViewModel方法
- CakePHP Model中( 获取Session)使用Component的方法
- 在子视图中实现调用控制器里面的跳转方法这里介绍三种方法