2

我有一个表对象,它有 2 个外键字段(user_id 和teacher_id)。为 X 表生成实体后,实体仅包含 $user 和 $teacher 属性,这迫使我使用关联对象而不是 id。所以假设我知道我的对象的 user_id 和 teacher_id,而不是这样做:

$object->setUserId(1)

我要做:

$user = $this->getDoctrine()->getRepository('MyBundle:Users')->find(2);
$object->setUser($user)

有没有办法直接使用 id 来避免检索与每个 id 关联的整个对象?

4

1 回答 1

5

框架建议在设置关联值时使用对象。仍然——你确定记录还没有加载到内存中吗?如果是,则不会导致额外的 SQL 语句执行。

如果确实需要在不加载对象的情况下更新关联,可以

  • 运行本机 SQL;
  • 尝试手动创建 Doctrine Proxy 对象并设置它。

EntityManager您可以使用方法获取代理对象getReference

$object->setUser($this->getDoctrine()->getReference('MyBundle:Users', 2));
于 2012-10-22T11:15:39.390 回答