gpt4 book ai didi

mongodb - ArrayCollection 中的命名集合键

转载 作者:可可西里 更新时间:2023-11-01 10:43:50 25 4
gpt4 key购买 nike

我正在寻找一种为 ODM ArrayCollection 关联数组键的方法。

实体具有以下映射:

/**
* $fields
*
* The entities fields
*
* @ODM\ReferenceMany(targetDocument="JobboardEntity\Entity\EntityField", sort={"name"="asc"}, cascade={"all"})
* @var \Doctrine\Common\Collections\ArrayCollection
*/
protected $fields;

/**
* addField
*
* Add a single field to the field collection
*
* @param EntityField $field The field to add
*/
public function addField(EntityField $field)
{
$this->fields[$field->getFieldName()] = $field;
}

请注意,在 addField 方法中,我为项目提供了 $field->getFieldName() 的索引。

不幸的是,Doctrine 忘记了这个键并返回一个 ArrayCollectionnumeric 索引而不是先前设置的字符串。

这意味着为了正确实现 $this->hasField($fieldName)$this->getField($fieldName) 我需要循环收集并测试 fieldName

例如

public function hasField($fieldName)
{
foreach($this->fields as $field) {
if ($fieldName === $field->getFieldName()) {
return true;
}
}
return false;
}

在我看来,这是一个糟糕的解决方案,因为我需要加载整个集合来检查 key !

拥有looked into the issue我可以看到 ORMthis implemented with IndexBy mapping .

Doctrine ODM 有没有类似的功能?实现此目标的正确方法是什么?

最佳答案

看看 Collection Strategies .

如果您使用 @ODM\ReferenceMany(strategy="set")(也适用于 EmbedMany),集合将存储为 BSON 对象,并在加载时设置相应的键:

我不完全确定对数据库本身的性能影响。我想将集合存储为 BSON 对象有点慢,但正如您所说,加载整个集合(以及您正在检查的实体)并不是一件好事,它有助于使代码更简洁。

关于mongodb - ArrayCollection 中的命名集合键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22833368/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com