php - cakephp - 修改和保存数据

标签 php mysql cakephp

我最近一直在尝试学习 cakephp,但我很难找到任何有关在修改数据后将数据存储到表中的教程。我习惯于完全控制 PHP 中的所有内容,因此很难适应 MVC 的自动化过程。

我认为第一个好的实验是接受一个输入并将一个字母连接到它(我们就说“m”)。然后,将原始值和连接后的值存储在一个表中,其中包含字段“orignal”和“concatenated”。因此,如果我输入“hello”,原始字段中的值将是“hello”,而连接后的字段将是“hellom”。

我的问题是模型是否负责连接原始值?它也会节省开支还是 Controller 的责任?

这是我的代码:我收到以下错误。 fatal error :在第 6 行的/Applications/XAMPP/xamppfiles/htdocs/cake/app/Model/Concatenate.php 中的非对象上调用成员函数 save()

View/Concatenates/add.php
<h1>Add Something</h1>
<?php

   echo $this->Form->create('Concatenate');
   echo $this->Form->input('original');
   echo $this->Form->end('Add Numbers');

?>

现在是模型

class Concatenate extends AppModel {

function saveConcat($original,$concatenated) {
        $this->set(array(
        'original' => $original,
        'concatenated' => $concatenated));
        $this->save();
        }

}

?>

现在是 Controller

<?php
class ConcatenatesController extends AppController {

public  $helpers = array('Html', 'Form');
public $components = array('Session');

public function index() {
     $this ->set('concatenates', $this->Concatenate->find('all'));  
} 

 public function add() {
    if ($this->request->is('post')) {
        $original = $this->request->data['Concatenate']['original'];
        $concatenated =  $original."m" ;
        $this->Concatenate->saveConcat($original,$concatenated);
    }
}

function isempty(){ //used to check if there is data in the table. If there isn't any, "no data" will be displayed
       $mysorts = $this->Concatenate->find('all');
       $this->set('concatenates', $mysorts);
 }
}
?>

最佳答案

这是关于胖模型/瘦 Controller 的永无止境的争论(或偏好,反之亦然)。

保存而言,模型绝对应该处理相应的逻辑。虽然,您很可能会从 Controller 调用它,例如 $myModel->save($data);

在连接值时,我会亲自在 Controller 中处理它,因为它是与模型不直接相关的业务逻辑。例如,您可能希望连接一个字符串并将其发送到 View 。

[编辑]

免责声明:我对 CakePHP 的经验几乎为零,但基本原理是相同的。

您提到您无法让它工作,所以我注意到一件事是您的模型中有一个名为 Concatenate() 的函数。这是构造函数的 PHP4 风格,不再是“最佳实践”(当然除非您正在运行 PHP4,但您到底为什么要这样做)。事实上,它很可能在不久的将来完全被弃用。 PHP5 构造函数的方式是使用 __construct() 函数。如果您决定使用构造函数,我会确保在其中调用 parent::__construct(); 以确保正确加载父 AppController 类。

在查看 Concatenate() 方法的功能时,我怀疑您无论如何都打算将它作为构造函数。将该函数重命名为类似 saveConcat() 的清晰名称。此外,我不确定我是否会使用 $this->request->data 作为您的源,以防您希望能够重用此函数并使用任何值调用它。在那种情况下,我会向函数添加一个参数

class Concatenate extends AppModel {

    function saveConcat($data) {

       if ($this->Concatenate->save($data)) { 

          $this->Session->setFlash('Your post has been saved.');
          $this->redirect(array('action' => 'index'));

       } else {

          $this->Session->setFlash('Unable to add your post.');

       }

    }

}

然后在您的 Controller 中的某处,您必须实际调用此函数。将 Controller 中的 add() 函数修改为如下所示:

public function add() { 

   if ($this->request->is('post')) {

      // Put data into array for saving
      $data[] = array( 'original' => $this->request->data );
      $data[] = array( 'concatenated' => $original."m" );

      // Call model function to save it
      $this->Concatenate->saveConcat($data);

   }

}

[编辑 2]

I just can't figure out why I'm getting the error: Call to a member function save() on a non-object.

当您从 Concatenate 类内部调用 $this->Concatenate->save 时,这意味着您正在尝试访问名为 Concatenate 的类中的变量并执行一个功能。当然两者都不存在。原因是您需要这样调用对象本身:

$this->save("blah blah");

该方法(我假设是 AppModel 类的父方法)将被调用,引用 Concatenate 对象的当前实例。

关于php - cakephp - 修改和保存数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9865594/

相关文章:

php - CakePHP:直接使用验证函数

php - 根据外键编辑计划

php - PDO 查询正常,但未提供最终结果

mysql - SQL 日期范围 - 如果没有提供起点则选择全部?

c# - 对象必须实现 IConvertible MySQL C#

javascript - 计算存储在mysql中的剩余字符

php - CakePHP 关联错误 : Call to a member function find() on a non-object

php - 使用 SwiftMailer 发送的邮件不使用样式 block

PHP 命名空间和动态类名

CakePHP 2.0 不使用我的 Ajax 布局