Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.52/103: Рейтинг темы: голосов - 103, средняя оценка - 4.52
 Аватар для Накурикота
2 / 2 / 4
Регистрация: 14.08.2013
Сообщений: 105

Использование CASE в UPDATE

18.03.2015, 11:20. Показов 21715. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Есть такой запрос
SQL
1
2
3
4
5
6
7
8
SELECT id, name, SUM(one_price), price,
'Rezult' =
  CASE
    WHEN SUM(one_price) <> price THEN '***BAD***'
      ELSE 'OK'
  END
FROM stor 
GROUP BY id,name,price
Запрос отображает товар со склада (поле one_prise -цена одного товара, price -общая цена группы товара). Если сумма поштучных товаров не равна общей цене товара тогда в поле Rezult = ***BAD*** иначе OK
Подскажите пожалуйста можно ли сделать UPDATE по таблице где, Если сумма поштучного товара не ровна общей цене товара то записать в поле price сумму поштучного товара.
Пробовал сделать так:
SQL
1
2
3
4
5
6
7
UPDATE stor
SET price = 
    ( CASE
         WHEN (price <> SUM(one_price)) THEN (SELECT SUM(a.one_price)FROM stor a WHERE a.id = id)
         ELSE (SELECT SUM(b.one_price)FROM stor b  WHERE b.id = id)
       END
    )
Но выдает исключение: An aggregate may not appear in the set list of an UPDATE statement.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.03.2015, 11:20
Ответы с готовыми решениями:

Использование CASE?
Доброго времени суток. Вопрос. Есть селект из которого нужно получить данные CASE`ом или любым другим доступным методом. ...

Использование CASE в функции (ошибка синтаксиса)
Мне нужно написать функцию которая будет считать для студентов номер курса основываясь на строке с названием группы. Получается она должна...

Использование insert и scope_identity внутри update
Есть две таблицы: tbl1 и tbl2. Необходимо в первой создать новую строку, а ID новой строки записать в одно из полей второй таблицы. ...

8
2 / 2 / 2
Регистрация: 16.10.2012
Сообщений: 69
18.03.2015, 15:09
Вы понимаете, что у вас в THEN и ELSE одинаковые выражения

T-SQL
1
2
3
4
5
         CASE
         WHEN (price <> SUM(one_price))
         THEN (SELECT SUM(a.one_price)FROM stor a WHERE a.id = id)
         ELSE (SELECT SUM(b.one_price)FROM stor b  WHERE b.id = id)
         END
А так же: немного не понял вашу задачу, попробуйте правильно поставить ТЗ.
0
 Аватар для Накурикота
2 / 2 / 4
Регистрация: 14.08.2013
Сообщений: 105
18.03.2015, 18:26  [ТС]
Я прекрасно это понимаю.
даже если сделать так
T-SQL
1
2
3
4
5
CASE
         WHEN (price <> SUM(one_price))
         THEN (SELECT SUM(a.one_price)FROM stor a WHERE a.id = id)
         ELSE 0
         END
Исключение будет тоже.
Необходимо произвести исправление колонки prise в том случаи если sum(one_priсe) не равна price? на что изменить? на sum(one_priсe)
0
 Аватар для Metall_Version
2152 / 1289 / 516
Регистрация: 04.03.2014
Сообщений: 4,092
18.03.2015, 23:34
Накурикота, ибо в условии нельзя использовать агрегатную функцию, вам же сервер написал об этом "WHEN (price <> SUM(one_price))" , если нужна сумма one_price по всей таблице то это нужно запросом получать

T-SQL
1
2
3
4
5
6
7
UPDATE stor
SET price = 
     CASE
         WHEN (price <> (SELECT SUM(one_price)FROM stor)) 
         THEN (SELECT SUM(a.one_price)FROM stor a WHERE a.id = id)
         ELSE (SELECT SUM(b.one_price)FROM stor b  WHERE b.id = id)
       END
1
 Аватар для Накурикота
2 / 2 / 4
Регистрация: 14.08.2013
Сообщений: 105
19.03.2015, 08:14  [ТС]
Возможно сможете помочь еще с одной закавыкой. Которая связана с предыдущим вопросом.
Изобразил на рисунке две таблицы в первой таблице у нас есть товар с ценой за шт. Как мне сделать Update что бы в поле price была сумма всех товаров как изображено во второй таблице?
Миниатюры
Использование CASE в UPDATE  
0
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
19.03.2015, 08:45
как-то я логики не увидел в формировании цены
0
 Аватар для Накурикота
2 / 2 / 4
Регистрация: 14.08.2013
Сообщений: 105
19.03.2015, 08:51  [ТС]
Цитата Сообщение от pincet Посмотреть сообщение
как-то я логики не увидел в формировании цены
Это нормально. Я тоже считаю что все как запутанно - но все же, возможен ли такой Update в данном случаи?
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
19.03.2015, 09:11
Цитата Сообщение от Накурикота Посмотреть сообщение
Как мне сделать Update что бы в поле price была сумма всех товаров как изображено во второй таблице?
T-SQL
1
2
3
4
5
6
7
8
9
10
with x as
(
 select
  price, sum(one_price) over (partition by name) as sump
 from
  Таблица
)
update x
 set
  price = sump;
1
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
19.03.2015, 09:20
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
with a(id,price) as
(
select 1,250
union all
select 2,300
union all 
select 3,500
)
 
update [table]  set price2=a.price 
from [table] join a
on a.id=[table].id
Добавлено через 1 минуту
с join поиграешься
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
19.03.2015, 09:20
Помогаю со студенческими работами здесь

UPDATE CASE statement
UPDATE statuses SET status = CASE document_id when '12345' then '2' end тип document_id: varchar2(30) not null тип...

SQL-запрос UPDATE/SET/CASE
Пытаюсь сделать запрос на изменение записей в БД из внешнего приложения при определенных условиях, используя конструкцию &quot;UPDATE ......

Использование switch-case
Помогите пожалуйста!!! мне нужно через case, но у меня он не работает, выдает ошибку. Как исправить? #include&lt;iostream&gt; ...

Циклы и использование case
Вот задание: Напишите программу, которая читает из cin входные числа (целые или вещественные) и суммирует, умножает или делит их,...

Использование switch case
Делаю текстовый редактор, чтобы не использовать много одинаковых методов, решил попробовать switch, через методы все работает. А со свитчем...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru