How to re-save the entity as another row in Doctrine 2

≡放荡痞女 提交于 2019-11-26 08:03:55

问题


Let\'s say I have entity $e. Is there any generic way to store it as another row, which would have the same entity data but another primary key?

Why I need this: I\'m implementing some sort of Temporal Database schema and instead of updating the row I just need to create another one.


回答1:


Try cloning and add the following method to your entity

public function __clone() {
    $this->id = null;
}

You may need to detach the entity before persisting it. I don't have my dev machine handy to test this right now.

$f = clone $e;
$em->detach($f);
$em->persist($f);
$em->flush();

Update

Just tried using a simple SQLite demo. You shouldn't need to do anything. The following worked for me without adding a __clone() method or doing anything else out of the ordinary

$new = clone $old;
$em->persist($new);
$em->flush();

Once flushed, the $new entity had a new ID and was saved as a new row in the DB.

I would still null the ID property via the __clone() method as it makes sense from a pure model view.

Update 2

Digging into the Doctrine code, this is because the generated proxy classes implement __clone() with this important line

unset($this->_entityPersister, $this->_identifier);



回答2:


Here's a simple strategy I used that doesn't involve excessive complexity:

$new->fromArray( $old->toArray() );
$new->id = NULL;


来源:https://stackoverflow.com/questions/9071094/how-to-re-save-the-entity-as-another-row-in-doctrine-2

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!