zoukankan      html  css  js  c++  java
  • cakephp 的query方法,直接写在controller中是否 有点不合适

    模型的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();

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

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

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

  • 相关阅读:
    漫游Kafka介绍章节简介
    poj 2309 BST 使用树阵lowbit
    华为-on练习--小写字符数的统计显示
    OpenMp高速分拣
    eclipse 于 Tomcat于 热部署 project
    2015第49周二
    2015第49周一
    2015第48周六
    2015第48周五
    2015第48周四
  • 原文地址:https://www.cnblogs.com/oxspirt/p/4565433.html
Copyright © 2011-2022 走看看