| 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 |