我有一个MainConfig
与实体具有一对一关系的LedConfig
实体。LedConfig
可以为空。
<?php
namespace ...
use Doctrine\ORM\Mapping as ORM;
...
/**
* @ORM\Entity
*/
class MainConfig
{
...
/**
* @ORM\OneToOne(targetEntity="...\LedConfig", cascade={"all"})
* @ORM\JoinColumn(name="led_config_id", referencedColumnName="id", nullable=true, unique = true)
*/
private $ledConfig = null;
...
}
<?php
namespace ...
use Doctrine\ORM\Mapping as ORM;
...
/**
* @ORM\Entity
*/
class LedConfig
{
/**
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @ORM\Column(type="float")
* @Assert\Type(type="float")
*/
private $lowerVoltageThreshold = 11.9;
/**
* @ORM\Column(type="float")
* @Assert\Type(type="float")
*/
private $upperVoltageThreshold = 12.85;
}
<?php
namespace ...;
use Symfony\Component\Form\AbstractType;
...
class MainConfigType extends AbstractType
{
...
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder
->add(...)
->add('ledConfig', LedConfigType::class)
...
}
...
}
我在不使用 Symfony 表单的情况下自动将主配置插入数据库。因此,如果我在代码中将 led config 设置为 null -led_config_id
主配置表中的字段正确设置为 NULL。
但是,当我更新主配置时,我使用的是通过 Symfony 表单处理的 HTTP PUT 请求。我正在使用 JSON,所以请求正文如下所示:
{..., "ssid":"test","runningMode":"force_on","led_config":null, ...}
处理完表单后,$ledConfig
MainConfig 实体中的属性被神奇地实例化为所有属性都设置为 NULLLedConfig
的对象?!并且数据库更新失败,因为它试图用空字段保存 LedEnttiy。为什么会这样?
有人可以帮助我并指出我做错了什么吗?
编辑:在表单验证之后,我可以在控制器更新操作中破解它:
/**
* @Route("...")
* @Method("PUT")
*/
public function updateMainConfigAction($id, Request $request)
{
$requestData = \GuzzleHttp\json_decode($request->getContent(), true);
...
if (!$form->isValid()) {
throw $this->throwApiProblemValidationException($form);
}
if (empty($requestData['led_config'])) {
$mainConfig->setLedConfig(null);
}
$em = $this->getDoctrine()->getManager();
$em->persist($mainConfig);
$em->flush();
...
}
但这有点脏……