如何从我的 ArrayCollection 获取数据?
How can I get data from my ArrayCollection?
我正在尝试通过 doctrine 从我的数组集合中加载数据:
$pages = $this->em->getRepository(Pages::class)->findAll();
结果是:
2 => Pages^ {#1598 ▼
-id: 3
-name: "cat"
-membergroup: PersistentCollection^ {#1603 ▼
-snapshot: []
-owner: Pages^ {#1598}
-association: array:16 [ …16]
-em: EntityManager^ {#278 …11}
-backRefFieldName: "pages"
-typeClass: ClassMetadata {#693 …}
-isDirty: false
#collection: ArrayCollection^ {#1604 ▼
-elements: []
}
#initialized: false
}
}
问题是,我希望成员组 ArrayCollection 中有一个元素。但是它是空的。
这与 Doctrine 的工作方式有关。如果您使用 findAll(),您的集合将被延迟加载。如果您尝试遍历集合并访问元素,您会发现它不是空的!
然而,延迟加载的集合通常不是一个好主意,因为它会导致大量的 SQL 查询。有几种方法可以解决这个问题,但这与问题无关。例如,您可以在存储库中进行自己的查询以避免这种情况。
这被称为 N+1 问题,它是所有 ORM 的常见问题
我正在尝试通过 doctrine 从我的数组集合中加载数据:
$pages = $this->em->getRepository(Pages::class)->findAll();
结果是:
2 => Pages^ {#1598 ▼
-id: 3
-name: "cat"
-membergroup: PersistentCollection^ {#1603 ▼
-snapshot: []
-owner: Pages^ {#1598}
-association: array:16 [ …16]
-em: EntityManager^ {#278 …11}
-backRefFieldName: "pages"
-typeClass: ClassMetadata {#693 …}
-isDirty: false
#collection: ArrayCollection^ {#1604 ▼
-elements: []
}
#initialized: false
}
}
问题是,我希望成员组 ArrayCollection 中有一个元素。但是它是空的。
这与 Doctrine 的工作方式有关。如果您使用 findAll(),您的集合将被延迟加载。如果您尝试遍历集合并访问元素,您会发现它不是空的!
然而,延迟加载的集合通常不是一个好主意,因为它会导致大量的 SQL 查询。有几种方法可以解决这个问题,但这与问题无关。例如,您可以在存储库中进行自己的查询以避免这种情况。
这被称为 N+1 问题,它是所有 ORM 的常见问题