0

我有一个文档用户包含

/**
 * @MongoDB\ReferenceOne(targetDocument="Image")
 */
private $image;

和一个文档ImageCollection,其中嵌入了名为 Image 的文档

/** 
 * @MongoDB\EmbedMany(targetDocument="Image") 
 */
private $images = array();

和我的嵌入文档图像,其中包含一些常用字段。这就是我尝试引用的方式(上传者是对某些用户的引用):

$rep = $this->dm->getRepository('Document\ImageCollection');
$qb = $rep->createQueryBuilder('Document\ImageCollection')->field('images.uploader.$id')->equals(new \MongoId($uploader->getId()));
$query = $qb->getQuery(); // get query
$result = $query->execute(); // do query
$arr = $result->toArray(); // get array
$item = array_shift($arr); // get first item of array

$newUser = new Documents\User();
$newUser->setName('Bob King');
$newUser->setImage($item->getImages()[0]);

结果将如下所示。问题是,我不知道为什么我的 $ref 和 $db 是正确的,而 $id 为空?

{
    "_id": ObjectID("51c2c357fa463404041b55ce"),
    "name": "Bob King",
    "image": {
        "$ref": "Image",
        "$id": null,
        "$db": "db_users_and_images"
    }
}
4

1 回答 1

1

问题是您无法引用嵌入式文档。您只能引用文档。仔细阅读 MongoDB 文档中的数据建模注意事项会发现,您必须在嵌入和引用之间进行选择

通常,当您只需要从其主文档访问嵌入式文档时(单向有多关系),请使用嵌入式文档。如果您需要从多个地方引用一个文档(它属于多个文档)或单独查询该文档,请使用引用。在 SO 上的引用和嵌入之间的权衡有很多问题,所以这里有一个很好回答的问题。

于 2013-09-01T15:22:08.737 回答