0

插入实体时,可以说article

Article::id
Article::text
Article::author -> User

文章有作者(ManyToOne)

User::id
User::name
User::created

如果我使用实体管理器在数据库中获取用户:

$user = $em->find(1);

$article = new Article();
$article->text = "balh blah";
$article->user = $user;

$em->persist($article);
$em->flush();

我只有一个正确的插入数据库。

INSERT INTO Article ...

现在,如果我使用存储在会话(或缓存)中的用户:

$user = $cache->find(1);
$user = $em->merge($user);

$article = new Article();
$article->text = "balh blah";
$article->user = $user;

$em->persist($article);
$em->flush();

我可以在 mysql 中看到 2 个查询:

INSERT INTO Article ...
UPDATE user set created="..." WHERE id = 1

如果用户具有更多的 OneToMany 关系,则它们中的每一个也会更新。知道用户实体没有改变,我不明白为什么Doctrine要执行这些更新。此外,只有创建的(日期时间)对象被更新,其他字段均未更新。

我没有级联设置,因此它不应该触发 Article persist() 上的任何内容。

任何人?

4

1 回答 1

0

您对 created_at 列的注释是什么?您的 User 类或 BaseUser 中的某处是否有 @PreUpdate 注释(如果它正在扩展)?

还; 尝试相同的方法,但不使用 $em->merge($user)。我从未使用过它,我什至不知道它的用途,但这可能是问题所在。

于 2013-05-09T11:20:43.010 回答