0

我的问题与从远程源提取数据并将其保存到本地数据库有关。使用saveAll(),可以正确保存父数据,但不能正确保存子数据。

protected function _saveLocal($_rekeyedData) {
        //Set the invoice header and line items models
        if (!isset($this->LocalHeader)) {
            $this->loadModel('LocalHeader');
            $this->LocalHeader->create();
//            $this->LocalHeader->set($_rekeyedData);
            if (!isset($this->LocalDetail)) {
                $this->loadModel('LocalDetail');
                $this->LocalDetail->create();
            }
        }

        if ($this->LocalHeader->saveAll($_rekeyedData, array('validate' => 'first'))) {
            $this->Session->setFlash('Your data has been saved.');
        } else {
            $this->Session->setFlash('Data load failed.');
        }
        debug( $this->LocalDetail->invalidFields() );
    }

在这个函数中,我加载模型,然后尝试saveAll(). 示例记录如下所示:

[1] => Array
    (
        [LocalHeader] => Array
            (
                [SOPNUMBE] => CR014076             
                [DUEDATE] => 2012-04-10 00:00:00
                [DOCDATE] => 2012-04-10 00:00:00
                [DOCAMNT] => 12000.00000
                [SUBTOTAL] => 12000.00000
            )

        [LocalDetail] => Array
            (
                [0] => Array
                    (
                        [ITEMNMBR] => BASIC SERVICE                  
                        [QUANTITY] => 1.00000
                        [UOFM] => EA       
                        [UNITPRCE] => 12000.00000
                        [TAXAMNT] => .00000
                        [CONTSTARTDTE] => 1900-01-01 00:00:00
                        [CONTENDDTE] => 1900-01-01 00:00:00
                        [SOPNUMBE] => CR014076             
                    )

            )

    )

保存的只是 LocalHeader 记录。我的预感是它与array('validate' => 'first'). 我想我需要在使用 validateMany 时做一些单独的事情saveAll(),但我不记得我在哪里看到过类似的东西,或者我只是编造的。

我已经阅读了 SO 中的许多相关问题,但所提供的解决方案都不适合我。

任何帮助表示赞赏。如果您有任何问题,请随时提问。

编辑:这是标题模型,这是详细模型

4

1 回答 1

0

我认为问题在于这些记录都不存在。根据文档

如果系统中不存在任何关联的模型记录(例如,您要同时保存新用户及其相关的个人资料记录),您需要先保存主模型或父模型。

您可以通过示例阅读更多信息。

于 2012-05-08T01:23:01.947 回答