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

gupuwyp2  于 2021-06-18  发布在  Mysql
关注(0)|答案(1)|浏览(370)

标题可能不太清楚,所以我会在这里详细解释(我必须错过一些明显的,但我不知道是什么)。
我正在使用vich上传包在我的项目中存储图片。我有两个与单向一对一关系链接的实体,第一个是所有者,包含指向包含文件的第二个实体的注解。这是第一个实体的代码部分:

...

     /**
     * @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);
    }
}

文件上传代码也在这里。它基本上包含文件描述(我正在使用扩展这个类的其他实体):

/**
 * @ORM\MappedSuperclass
 * @Vich\Uploadable
 */
class FileUpload
{

    /**
     * @var integer : stock the unique id of the file
     *
     * @ORM\Column(name="id", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    private $id;

    /**
     * @var string : stock the format of the file
     *
     * @ORM\Column(name="format", type="string", length=255)
     */
    private $format;

    /**
     * var string : stock the original name of the file
     *
     * @ORM\Column(name="alt", type="string", length=255)
     */
    private $alt;

    /**
     * @var integer : stock the size of the file (ko)
     *
     * @ORM\Column(name="size", type="integer")
     */
    private $size;

    /**
     * @var \DateTime
     *
     * @ORM\Column(name="updated_at", type="datetime", nullable=true)
     */
    private $updatedAt;

    /**
     * @var string $filename
     *
     * @ORM\Column(name="filename", type="string", length=255)
     */
    protected $filename;

    protected $file;

文件上传工作正常,一切都存储在我的项目和数据库的正确位置。当我试图通过第一个实体检索刚存储的内容时,问题就出现了。
这是我控制器中的代码:

$repo = $this->container->get('doctrine')->getRepository('CartongMSFBundle:MyFirstEntity');
        $test = $repo->find($theEntityWithAFile);

返回的对象包含除photo以外的所有预期信息,photo中的所有字段都为null。
因此,如果我试图通过“文件”回购中的findbyid获取特定的文件,它是有效的,但是当我试图通过我的第一个实体获取它时,它不是。
你知道吗(可能是注解中的错误?)

mqkwyuun

mqkwyuun1#

这似乎是一个典型的问题。在关联的情况下,默认情况下,条令不会从数据库关联实体加载,直到需要(例如,您调用 $myFirstEntity->getPhoto()->getFormat() ). 这称为延迟加载。
如果要将关联实体与第一个实体一起加载,则应将“获取”选项设置为“急切”:

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

相关问题