4

我不知道这是否是一个错误,但我正在使用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告诉我(通过查看 来确认DBDoctrine执行以下查询:

INSERT INTO test (field1, field2) VALUES (?, ?)
array(2) {
  [1]=>
  string(3) "foo"
  [2]=>
  NULL
}

如您所见,虽然我没有设置field2Doctrine但确实将它放在带有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;
}
4

1 回答 1

1

我想这是默认行为,因为在一个 INSERT 语句中创建完整记录可以被视为合乎逻辑。但我可能弄错了。拥有某种@ORM\Column(type="boolean", columnDefinition="TINYINT(1) NULL DEFAULT 0")可以被视为一种黑客攻击,但解决方案。我建议您查看数据库记录插入逻辑。

于 2012-10-24T08:28:05.257 回答