php - CakePHP saveAll() 函数问题

标签 php mysql database cakephp

我正在尝试将记录以及关联记录保存到表中。主表称为quotes,它有一个到quote_items 表的许多链接。 quote_items 属于报价

当我尝试保存时,它会将记录保存在 quote 中,但不会将记录保存在 quote_items 中 .

下面是我的报价添加功能

    function add() {
    if (!empty($this->data)) {
        $this->Quote->create();
        if ($this->Quote->saveAll($this->data)) {
            $this->Session->setFlash(__('The Quote has been saved', true));
            //$this->redirect(array('action'=>'index'));
        } else {
            $this->Session->setFlash(__('The Quote could not be saved. Please, try again.', true));
        }
    }
    $this->Quote->recursive = 2;
    $statuses = $this->Quote->Status->find('list');
    $contacts = $this->Quote->Contact->find('list');
    $this->set(compact('statuses', 'contacts'));
}

报价 View /表单设置

    <?php echo $form->create('Quote', array('action' => 'add'));?>
    <fieldset>
        <legend><?php __('Add Quote');?></legend>
    <?php
        echo $form->input('Quote.name');
        echo $form->input('Quote.revision');
        echo $form->input('Quote.status_id');
        echo $form->input('Quote.contact_id');
        echo $form->input('quote_item.product_id');
        echo $form->input('quote_item.name');
        echo $form->input('quote_item.price');
        echo $form->input('quote_item.description');
        echo $form->input('Quote.totalcost');
    ?>
    </fieldset>
<?php echo $form->end('Submit');?>

提交表单时返回的数组

    Array ( 
    [quote] => Array ( 
                [name] => Test 
                [revision] => 1 
                [status_id] => 1 
                [contact_id] => 1 
                [totalcost] => 123 
              ) 

    [quote_item] => Array ( 
                [product_id] => 1
                [name] => test 
                [price] => 123 
                [description] => tes 1234 
              ) 
) 

这似乎完全遵循 cakephp 文档中列出的内容,所以我无法弄清楚为什么它不起作用 - http://book.cakephp.org/view/84/Saving-Related-Model-Data-hasOne-hasMany-belongsTo

提前致谢

最佳答案

构建表单的正确方法是:

echo $form->input('Quote.name');
...
echo $form->input('QuoteItem.0.product_id');
echo $form->input('QuoteItem.0.name');
...
echo $form->input('QuoteItem.1.product_id');
echo $form->input('QuoteItem.1.name');

生成的数组应如下所示:

array(
    'Quote' => array(
        'name' => 'Test'
        ....
    ),
    'QuoteItem' => array(
        0 => array(
            'product_id' => 1
            'name' => 'test'
            ...
        )
        1 => array(
            'product_id' => 2
            'name' => 'test'
            ...
        )
    )
)

根据命名约定,模型名称是驼峰式的(ModelName,而不是 model_name)。另外,由于 Quote hasMany QuoteItems,QuoteItem 数组需要由许多 QuoteItem 数组组成。希望这是有道理的。 :)

关于php - CakePHP saveAll() 函数问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2152518/

相关文章:

php - 如何使用带有背景的 div 集创建 jpeg - PHP/jQuery

php - 如何在 YAML 中使用 API 平台过滤器?

mysql - 数据库设计布局

mysql - database.yml 中的 utf8 编码问题在插入时丢弃字符串

mysql - Apache 和 MYSQL 未在 XAMPP 中启动

php - 用 PHP 编写编译器

php - 如何在运行时为数组索引指定一个命名键

database - 在 Couchbase 中使用 N1QL 从对象的对象中获取所有唯一键

jquery - MySQL - 连接或插入查询结果

mysql - 把多个程序的数据插入一张表可以吗?