Mysql 在Symfony中,find()方法对具有一对一单向关系的实体返回null

Mysql 在Symfony中,find()方法对具有一对一单向关系的实体返回null,mysql,symfony,doctrine,one-to-one,vichuploaderbundle,Mysql,Symfony,Doctrine,One To One,Vichuploaderbundle,标题可能不太清楚,所以我将在这里详细解释(我必须错过一些明显的东西,但我不知道是什么) 我正在使用Vich uploader捆绑包在我的项目中存储图片。我有两个实体用单向一对一关系链接,第一个是所有者,包含指向包含文件的第二个实体的注释。 这是第一个实体的代码部分: ... /** * @ORM\OneToOne(targetEntity="Cartong\MyBundle\Entity\Mysql\EntityContainingTheFile") * @ORM

标题可能不太清楚,所以我将在这里详细解释(我必须错过一些明显的东西,但我不知道是什么)

我正在使用Vich uploader捆绑包在我的项目中存储图片。我有两个实体用单向一对一关系链接,第一个是所有者,包含指向包含文件的第二个实体的注释。 这是第一个实体的代码部分:

...

     /**
     * @ORM\OneToOne(targetEntity="Cartong\MyBundle\Entity\Mysql\EntityContainingTheFile")
     * @ORM\JoinColumn(name="photo_id", referencedColumnName="id")
     */
    private $photo;

...
以及包含该文件的文件:

 /**
 * @ORM\Entity
 * @ORM\HasLifecycleCallbacks()
 * @Vich\Uploadable
 */
class EntityContainingTheFile extends FileUpload
{
    /**
     * @var UploadedFile
     * @Vich\UploadableField(mapping="my_pictures", fileNameProperty="filename")
     */
    protected $file;

    /**
     * @return UploadedFile
     */
    public function getFile()
    {
        return parent::getFile();
    }

    /**
     * @param UploadedFile $file
     */
    public function setFile(File $file)
    {
        return parent::setFile($file);
    }
}
文件上传代码也在这里。它基本上包含文件描述(我正在使用扩展此类的其他实体):

文件上传工作正常,所有内容都存储在我的项目和数据库的正确位置。当我试图通过第一个实体检索刚刚存储的内容时,就会出现问题

这是我控制器中的代码类型:

$repo = $this->container->get('doctrine')->getRepository('CartongMSFBundle:MyFirstEntity');
        $test = $repo->find($theEntityWithAFile);
返回的对象包含除照片以外的所有预期信息,照片中的所有字段均为空

因此,如果我试图通过“文件”回购协议中的findById获取特定文件,它是有效的,但当我试图通过我的第一个实体获取它时,它不是


有什么想法吗?(可能是注释中的错误?

这似乎是一个典型的问题。在关联的情况下,默认情况下,条令不会从数据库关联的实体加载,直到需要(例如,您调用
$myFirstEntity->getPhoto()->getFormat()
)。这称为延迟加载

如果希望将关联实体与第一个实体一起加载,则应将doctrine fetch option设置为:

/**
 * @ORM\OneToOne(targetEntity="EntityContainingTheFile", fetch="EAGER")
 * @ORM\JoinColumn(name="photo_id", referencedColumnName="id")
 */
private $photo;
/**
 * @ORM\OneToOne(targetEntity="EntityContainingTheFile", fetch="EAGER")
 * @ORM\JoinColumn(name="photo_id", referencedColumnName="id")
 */
private $photo;