Conditions | 2 |
Paths | 2 |
Total Lines | 17 |
Code Lines | 11 |
Lines | 0 |
Ratio | 0 % |
Changes | 1 | ||
Bugs | 0 | Features | 0 |
1 | <?php |
||
18 | private static function batchUpdateColumn(string $table, string $column, array $indices) |
||
19 | { |
||
20 | $cases = []; |
||
21 | $ids = []; |
||
22 | $params = []; |
||
23 | |||
24 | foreach ($indices as $index => $modelId) { |
||
25 | $id = (int) $modelId; |
||
26 | $cases[] = "WHEN {$id} then ?"; |
||
27 | $params[] = $index; |
||
28 | $ids[] = $id; |
||
29 | } |
||
30 | |||
31 | $ids = implode(',', $ids); |
||
32 | $cases = implode(' ', $cases); |
||
33 | |||
34 | DB::update("UPDATE `{$table}` SET `{$column}` = CASE `id` {$cases} END WHERE `id` in ({$ids})", $params); |
||
35 | } |
||
37 |