21st
Июл

Групповое обновление полей таблицы в Mysql

Posted by Chas under Пост-обзор

Имеется массив id записей таблицы tab. Нужно у этих записей обновить поле count. Пример:
id массив: 2, 12, 1, 3, 3, 3, 1
Я делаю так:

'UPDATE `tab` SET `count`=`count`-1 WHERE `id` IN (2, 12, 1, 3, 3, 3, 4);');

Но так не правильно, т.к. обновляется только на 1, а т.к. у нас имеется id=3 три раза, значит должно обновиться это поле на 3. Массив может меняться, могут быть одинаковые id, а могут быть и все разные. Сам вопрос, как это лучше сделать, или придётся разными запросами делать?

Аватар:
Формировать строку IN выбирая только не повторяющиеся и одновременно удаляя из массива выбранные. Выполить запрос и по-новой формирование строки IN из остатка массива и т.д. Для приведенного примера получится три UPDATE. Одним запросом можно в set CASE WHEN использовать, но эту строчку прийдется программно сформировать тогда. Не знаю приемлимо ли это:

UPDATE 'tab'
SET 'count'='count' - CASE WHEN 'id'=3 THEN 3 ELSE 1 END
WHERE 'id' IN (2, 12, 1, 3, 4);

тема на форуме

Похожие статьи

Теги: |