Последние записи
- TChromium (CEF3), сохранение изображений
- Как в Delphi XE обнулить таймер?
- Изменить цвет шрифта TextBox на форме
- Ресайз PNG без потери прозрачности
- Вывод на печать графического файла
- Взаимодействие через командную строку
- Перенести программу из Delphi в Lazarus
- Определить текущую ОС
- Автоматическая смена языка (раскладки клавиатуры)
- Сравнение языков на массивах. Часть 2
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
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);
Похожие статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
пеллетные котлы
Пеллетный котел Emtas
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)