几分钟前,我在 Doctrine2 中发现了一个错误。
我在我的实体中添加了一些字段,然后刷新了 mysql 表,然后我注意到新数据没有存储在表中。
尝试了 var_dump "->getXXX()" 的值,结果是正确的。
这是使用的代码:
$user->setName($name);
$user->setSurname($surname);
if($country)
$user->setCountry($country->getId());
//New code
if($province > 0)
$user->setProvince($province);
if($town > 0)
$user->setTown($town);
var_dump($user->getProvince(), $user->getTown()); //Works OK
$em->persist($user); // Only persists values before Province.
$em->flush();
谢谢并恭祝安康!
已编辑
关于我的实体的信息:
class Users
{
/**
* @var integer $id
*
* @ORM\Column(name="id", type="bigint")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @var string $name
*
* @ORM\Column(name="name", type="string", length=50)
*/
private $name;
/**
* @var string $surname
*
* @ORM\Column(name="surname", type="string", length=95)
*/
private $surname;
/**
* @var string $mail
*
* @ORM\Column(name="mail", type="string", length=80, unique=true)
*/
private $mail;
/**
* @var string $password
*
* @ORM\Column(name="password", type="string", length=255)
*/
private $password;
/**
* @var $country
*
* @ORM\Column(name="country", type="integer")
*/
private $country;
/**
* @var $province
*
* @ORM\Column(name="province", type="integer")
*/
private $province;
/**
* @var $town
*
* @ORM\Column(name="town", type="integer")
*/
private $town;
}
Country、province 和 town 是来自同名表的 id。我尝试使用 ManytoOne 关联更改字段的类型,但它让我在 Doctrine2 生成的 SQL 上出错。这似乎是一个缓存错误,但我无法解决它。