我有一个表Object,它有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关联的整个对象?
答案 0 :(得分:3)
框架建议在设置关联值时使用对象。仍然 - 你确定记录还没有加载到内存中吗?如果是,则不会导致执行额外的SQL语句。
如果您确实需要在不加载对象的情况下更新关联,则可以
您可以使用EntityManager
方法getReference
:
$object->setUser($this->getDoctrine()->getReference('MyBundle:Users', 2));