gpt4 book ai didi

php - Symfony Doctrine One to Many 不插入外键

转载 作者:行者123 更新时间:2023-12-05 08:10:04 26 4
gpt4 key购买 nike

我在持久化具有一个或多个 OneToMany-Childs 的实体时遇到了烦人的问题。

我有一个“Buchung”实体,它可以有多个“Einsatztage”(可以翻译成一个有很多天的事件)

在“我有的Buchung实体”

/**
* @param \Doctrine\Common\Collections\Collection $property
* @ORM\OneToMany(targetEntity="Einsatztag", mappedBy="buchung", cascade={"all"})
*/
private $einsatztage;

$einsatztage 被设置为 __constructor() 中的 ArrayCollection()。

然后是“Einsatztag”实体,它有一个 $Buchung_id 变量来引用“Buchung”

/**
* @ORM\ManyToOne(targetEntity="Buchung", inversedBy="einsatztage", cascade={"all"})
* @ORM\JoinColumn(name="buchung_id", referencedColumnName="id")
*/
private $Buchung_id;

现在,如果我尝试将对象持久保存到数据库,“Einsatztag”表的外键始终为空。

$buchung = new Buchung();

$buchung->setEvent(         $r->request->get("event_basis"));
$buchung->setStartDate(new \DateTime($r->request->get("date_from")));
$buchung->setEndDate(new \DateTime($r->request->get("date_to")));


$von = $r->request->get("einsatz_von");
$bis = $r->request->get("einsatz_bis");
$i = 0;
foreach($von as $tag){
$einsatztag = new Einsatztag();

$einsatztag->setNum($i);
$einsatztag->setVon($von[$i]);
$einsatztag->setBis($bis[$i]);

$buchung->addEinsatztage($einsatztag);
$i++;
}

$em = $this->getDoctrine()->getManager();

$em->persist($buchung);

foreach($buchung->getEinsatztage() as $e){
$em->persist($e);
}
$em->flush();

最佳答案

首先,你必须明白 Doctrine 和 Symfony 不能在你的实体中使用 id。在 Einsatztag 实体中,你的属性不应该被称为 $Buchung_id 因为它是 buchung 的一个实例而不是你会在那里找到的 id。

此外,在您的循环中,您将 Einsatztag 添加到 Buchung。但是你处理反向集吗?

我这样做是为了始终反转实体的设置/添加。

别动队

public function setBuchung(Buchung $pBuchung, $recurs = true){
$this->buchung = $pBuchung;

if($recurs){
$buchung->addEinsatztag($this, false);
}
}

布仲

public function addEinsatztag(Einsatztag $pEinsatztag, $recurs = true){
$this->einsatztages[] = $pEinsatztag;

if($recurs){
$pEinsatztag->setBuchung($this, false);
}
}

然后,什么时候调用

$buchung->addEinsatztag($einsatztag);

或者

$einsatztag->set($buchung);

关系将在双方设置,使您的 FK 被设置。请注意这一点,如果使用不当,您会出现重复输入等行为。

更简单,您可以使用默认的 getter/setter 并在关系的两边调用它们,使用您已有的,如下所示:

$einsatztag->set($buchung);
$buchung->addEinsatztag($einsatztag);

希望对您有所帮助 ;)

关于php - Symfony Doctrine One to Many 不插入外键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28135863/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com