重复模型及其关联

时间:2015-09-03 13:44:44

标签: cakephp model associations duplication

我遇到了this post给出了如何做到这一点的答案,但这对我来说并不适合。

我有一个名为SitePage的模型,其中有许多SitePageGroup,其中有许多SitePageContent

// SitePage Model
public $hasMany = array(
    'SitePageGroup' => array(
        'className' => 'FoCMS.SitePageGroup',
        'foreignKey' => 'site_page_id',
        'dependent' => FALSE,
    ),
);

// SitePageGroup Model
public $belongsTo = array(
    'SitePage' => array(
        'className' => 'FoCMS.SitePage',
        'foreignKey' => 'site_page_id',
    ),
);

public $hasMany = array(
    'SitePageContent' => array(
        'className' => 'FoCMS.SitePageContent',
        'foreignKey' => 'site_page_group_id',
        'dependent' => FALSE,
    ),
);

// SitePageContent Model
public $belongsTo = array(
    'SitePageGroup' => array(
        'className' => 'FoCMS.SitePageGroup',
        'foreignKey' => 'site_page_group_id',
    ),
);

使用该链接问题中的答案我看到父模型SitePage被复制,但相关模型正在从原始模型中删除并与新模型相关联。

$record = $this->SitePage->find('first', array('condition' => array('SitePage.id' => $id)));
unset($record['SitePage']['id'], $record['SitePageGroup']['id'], $record['SitePageGroup']['SitePageContent']['id'] /* further ids */);
$this->SitePage->create();
$record['SitePage']['name'] = $record['SitePage']['name'].'-copy';
$record['SitePage']['friendly_name'] = $record['SitePage']['friendly_name'].' Copy';
if($this->SitePage->saveAll($record)){
    $this->Session->setFlash('The site page has been saved', 'fo_message');
    $this->redirect(array('action' => 'index'));
}else{
    $this->Session->setFlash('The site page could not be saved. Please, try again.', 'fo_message');
}

更新

调试我正在尝试重置的记录我看到以下

array(
    'SitePage' => array(
        'name' => 'test',
        'friendly_name' => 'Test',
        'order' => '82',
        'created' => '2015-09-03 19:16:40',
        'modified' => '2015-09-03 19:20:27'
    ),
    'SitePageGroup' => array(
        (int) 0 => array(
            'id' => '55e88087-a4dc-4c37-89dc-f9c172b40463',
            'site_page_id' => '55e88078-16c8-46ce-bf02-fa5372b40463',
            'name' => 'group-1',
            'friendly_name' => 'Group 1',
            'order' => '1',
            'created' => '2015-09-03 19:16:55',
            'modified' => '2015-09-03 19:16:55'
        ),
        (int) 1 => array(
            'id' => '55e8809e-d018-4ebe-a4cf-fbef72b40463',
            'site_page_id' => '55e88078-16c8-46ce-bf02-fa5372b40463',
            'name' => 'group-2',
            'friendly_name' => 'Group 2',
            'order' => '2',
            'created' => '2015-09-03 19:17:18',
            'modified' => '2015-09-03 19:17:18'
        )
    )
)

我得到这个结果的方法就是这样做

$sitePage = $this->SitePage->find('first', array(
    'conditions' => array(
        'SitePage.id' => $id,
    ),
));

unset($sitePage['SitePage']['id'], $sitePage['SitePageGroup']['id'], $sitePage['SitePageGroup']['SitePageContent']['id'], $sitePage['SitePageGroup']['site_page_id'], $sitePage['SitePageGroup']['SitePageContent']['site_page_group_id'] /* further ids */);
debug($sitePage);
die();

但同样您也可以在调试输出中看到第3级关联模型未被包含,SitePageGroup中的每一个都应该有SitePageContent

我认为对SitePageGroup数组的简单循环应该重置id并将外键设置为null,但我想我还需要以某种方式包含属于{SitePageContent的{​​{1}} 1}}所以我也可以重置它们。

1 个答案:

答案 0 :(得分:3)

您需要确保在保存之前将所有主键和外键都设置为null。您似乎只是重置模型的主键,但Cake需要知道外键需要生成,以便它们引用新记录。

在调用$record之前,可能需要使用debug($record);检查该数组中的所有内容是否已正确设置/重置,以确保副本按预期工作。

<强>更新

根据您在更新后的问题中发布的数组内容,您似乎没有从保存数据中删除所有主键和外键。您需要确保从要保存的所有内容中删除这些内容,包括许多关联。

如果您查看数组,您应该会看到unset($sitePage['SitePageGroup']['id'])不会删除SitePageGroup数据的主要ID,因为您未设置的数据与您{中的数组路径不对应{1}}数组。

您可以使用CakePHP的Hash utility to remove数组中的主键: -

$sitePage

同样的外键: -

$sitePage = Hash::remove($sitePage, 'SitePageGroup.{n}.id');