6

我有一个嵌入了文档的文档。当我第一次创建一个对象时,一切正常,但是当我尝试更新一个文档时,嵌入的文档没有得到更新。

/** @MongoDB\Document */
class DocumentA
{
    /** @MongoDB\EmbedOne(targetDocument="DocumentB") **/
    protected $docB;

    /** @MongoDB\String */
    protected $valueA;
}

/** @MongoDB\EmbeddedDocument */
class DocumentB
{
    /** @MongoDB\String */
    protected $valueB;
}

在我的应用程序中,我查询文档、更新值并将它们保存到数据存储中。

// Variant A – Does not work
$document = ... // find from data store
$document->setValueA('Hello World');
$document->getDocB()->setValueB('foo baz');

$om->persist($document);
$om->flush();

如果我不更新嵌入文档,而是设置一个新文档,一切正常:

// Variant B - Does work
$document = ... // find from data store
$document->setValueB('Hello World 2');
$document->setDocB(new DocumentB());
$document->getDocB()->setValueB('foo baz 2');

$om->persist($document);
$om->flush();

正如我所说,变体 B 工作正常。但是,在我的应用程序中,文档更复杂,每次我必须更新嵌入文档时为嵌入文档创建一个新对象是不切实际的。有没有办法告诉 Doctrine ODM 查看嵌入文档的值来决定是否应该更新它?

4

2 回答 2

2

我遇到了完全相同的问题。事实证明,UnitOfWork 似乎无法计算嵌入其他文档的文档变更集,尽管我无法弄清楚为什么......结果,当我比较实际值和原始值时,单位工作显示两者的价值相同。与您的变体 A 交谈,当您

$document->getDocB()->setValueB('foo baz');

工作单元对旧值和新值都显示“foo baz”,并且不会将其识别为更改,因此不会更新它。

无论如何,这会导致一种解决方法:

$document = ... // find from data store
$document->setValueA('Hello World');
$docB = $document->getDocB();
$docB->setValueB('foo baz');
$om->detach($docB);
$om->persist($document);
$om->flush();

这使得工作单元将 $document 的 docB 识别为新设置的文档,并将按预期刷新它。

于 2013-03-20T13:29:58.557 回答
0

MongoDB 只有原子操作。您有以下选择: 1. 查询文档,找到合适的子文档,更新整个文档或其部分。优点:简单的逻辑缺点:非原子 2. 使用位置 $ 运算符是您的子文档在列表中。

于 2013-02-04T11:02:47.587 回答