我不知道这是否是一个错误,但我正在使用Doctrine 2.3.0
,我发现这种persist/flush
行为很奇怪。我有一个基本表:
------------------
| test |
------------------
| id INT | AI |
| field1 VARCHAR |
| field2 VARCHAR |
-----------------
当我仅通过设置创建条目时field1
:
$test = new Entities\test();
$test->setField1('foo');
$em->persist($test);
$em->flush();
Doctrine\DBAL\Logging\EchoSQLLogger
告诉我(通过查看 来确认DB
)Doctrine
执行以下查询:
INSERT INTO test (field1, field2) VALUES (?, ?)
array(2) {
[1]=>
string(3) "foo"
[2]=>
NULL
}
如您所见,虽然我没有设置field2
,Doctrine
但确实将它放在带有NULL
值的插入语句中。
我的所有实体都有这种行为,这是有问题的,因为在进行插入时,我DB
未设置的字段的默认值被覆盖NULL
。
这是 Doctrine 的预期默认行为吗,有没有办法关闭它(即排除我没有从INSERT
语句中设置的字段)?
我可能应该补充一点,我的实体是通过逆向工程自动生成的,并且其中一个字段的声明如下所示
/**
* @var string $field2
* // removing nullalble makes no diff.
* @ORM\Column(name="field2", type="string", length=45, nullable=true)
*/
private $field2;
/**
* Set field2
*
* @param string $field2
* @return Test
*/
public function setField2($field2)
{
$this->field2 = $field2;
return $this;
}