Doctrine executeUpdate数组参数

时间:2016-04-02 23:34:15

标签: php symfony doctrine-orm doctrine

如何使用数组进行doctrine更新,所以我不做每次循环(我只想对数据库进行1次调用)

$myarray = [1, 2, 3];
$sql = "UPDATE `mytable` SET is_processing = :is_processing, end_time=NOW() WHERE id = :id";

$result = $this->connection->executeUpdate(
    $sql,
    array(
        'is_processing' => false,
        'id' => $myarray // This is unknown number amount of array
    )
);

我想要达到的目标是: 它应该用字段is_processing = false更新表,endTime变为当前时间,其中id =数组指向的任何内容

1 个答案:

答案 0 :(得分:7)

在查询中使用IN子句。

UPDATE `mytable` SET is_processing = :is_processing, end_time=NOW() WHERE id IN(:ids)

然后

$result = $this->connection->executeUpdate(
    $sql,
    array(
        'is_processing' => false,
        'ids' => [3, 25]
    ),
    array(
        'ids' => \Doctrine\DBAL\Connection::PARAM_INT_ARRAY
    )
);