使用Doctrine访问Symfony 2中的一对多关系时出错

Sim*_*mon 11 php doctrine symfony

我有一个简单的一对多关系,当我尝试迭代集合时会出错.

来自"One"User.php

    /**
     * @ORM\OneToMany(targetEntity="UserMeasurement", mappedBy="measurements")
     */
    protected $measurements;
Run Code Online (Sandbox Code Playgroud)

和相应的"很多"UserMeasurement.php:

    /**
     * @ORM\ManyToOne(targetEntity="User", inversedBy="measurements", cascade={"persist"})
     * @ORM\JoinColumn(name="user_id", referencedColumnName="id")
     */
    protected $user;
Run Code Online (Sandbox Code Playgroud)

然而,当我尝试从命令运行时:

    $query = $em->createQuery(" SELECT user FROM AcmeFooBundle:User user");
    $users = $query->getResult();
    foreach ($users as $user) {
        print count($user->getMeasurements()->toArray());
    }
Run Code Online (Sandbox Code Playgroud)

我收到以下错误:

[ErrorException]
注意:未定义的索引:/Applications/MAMP/htdocs/Symfony/vendor/doctrine/lib/Doctrine/ORM/Persisters/BasicEntityPersister.php第1280行中的度量

我运行doctrine:schema:update --force命令,它说我在同步.

我错误地迭代了吗?

Pro*_*tic 17

在您的用户实体中,您有以下这一行:

@ORM\OneToMany(targetEntity="UserMeasurement", mappedBy="measurements")
Run Code Online (Sandbox Code Playgroud)

你告诉Doctrine的是它应该在UserMeasurement实体中查找一个名为的字段measurements,该字段不存在.你可能想要的是这个:

@ORM\OneToMany(targetEntity="UserMeasurement", mappedBy="user")
Run Code Online (Sandbox Code Playgroud)