如何使用数组进行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 =数组指向的任何内容
答案 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
)
);