Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/13: Рейтинг темы: голосов - 13, средняя оценка - 4.69
1 / 1 / 2
Регистрация: 25.02.2016
Сообщений: 141

ХП по расчету премии каждого продавца

31.03.2017, 17:56. Показов 2693. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день. Есть задание, которое нужно реализовать с помощью хранимой процедура:
--Сумму премий каждого продавца. Предположим, что премия
--рассчитывается по следующему алгоритму:
--o 1000-1299 грн премия 10% от закупочной стоимости книг
--o 1300-1499 грн премия 15% от закупочной стоимости книг
--o 1500-1999 грн премия 25% от закупочной стоимости книг
--o 2000-3000 грн премия 40% от закупочной стоимости книг

Сначала написал запрос, который по идеи работает

T-SQL
1
2
3
4
5
--написал для того чтобы понять правильно считается ли сумма
SELECT FirstName, LastName, SUM(Price), (SUM(Price) * 0.25 ) AS Bonus
FROM Sellings, Books, Sellers
WHERE Sellings.Id_Book = Books.Id AND Sellers.Id = Id_Seller 
GROUP BY FirstName, LastName
Теперь пишу саму хранимую процедуру

T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
CREATE PROC BonusForEachSeller 
AS
DECLARE @Bonus money, @S money
SELECT @S =Price FROM Books
BEGIN
SELECT FirstName, LastName, SUM(@S), SUM(@S) * @Bonus  AS Bonus
FROM Sellings, Books, Sellers
WHERE Sellings.Id_Book = Books.Id AND Sellers.Id = Id_Seller 
GROUP BY FirstName, LastName
 
IF (SUM(@S) >= 1000 AND SUM(@S) <= 1299)
BEGIN
SET @Bonus = 0.1
END
 
ELSE IF (SUM(@S) >= 1300 AND SUM(@S) <= 1499)
BEGIN
SET @Bonus = 0.15
END
 
ELSE IF (SUM(@S) >= 1500 AND SUM(@S) <= 1999)
BEGIN
SET @Bonus = 0.25
END
 
ELSE IF (SUM(@S) >= 2000)
BEGIN
SET @Bonus = 0.4
END
END
Но сумму считает неправильно и колонке Бонус стоит NULL
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
31.03.2017, 17:56
Ответы с готовыми решениями:

Написать разветвляющуюся программу по расчету премии от стажа
Доброго времени суток! Помогите пожалуйста с задачей: Размер премии сотрудникам рассчитывается из условий: стаж более 5 лет – 10%...

Создайте представление, для каждого продавца показывающее его реальный объём продаж на 01.01.2011
Создайте представление, для каждого продавца показывающее его реальный объём продаж на 01.01.2011. Представление должно содержать фамилию...

Разработать запрос, вычисляющий сумму премии каждого врача по-месячно
Помогите сделать запрос 4. вычислить сумму премии каждого врача по-месячно; Врачи получают такие премии: 10% от суммы до 300гр, 5% - до...

1
1040 / 856 / 335
Регистрация: 08.12.2016
Сообщений: 3,283
01.04.2017, 02:07
Лучший ответ Сообщение было отмечено Goret как решение

Решение

Цитата Сообщение от Goret Посмотреть сообщение
Но сумму считает неправильно и колонке Бонус стоит NULL
все правильно считает. Когда выполняется запрос, @Bonus IS NULL и в столбце умножения на @Bonus тоже NULL. Манипуляции с @Bonus после запроса и бессмысленны и умирают в теле процедуры так никому и не показанные

Добавлено через 14 минут
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
SELECT Sellers .*, Bonus
FROM (
 
SELECT 
  Id_Seller, 
  SUM(Price) *
  CASE
    WHEN SUM(Price) >= 2000 THEN 0.4  
    WHEN SUM(Price) >= 1500 THEN 0.25
    WHEN SUM(Price) >= 1300 THEN 0.15
    WHEN SUM(Price) >= 1000 THEN 0.1 
  END Bonus
FROM 
  Sellings 
  JOIN Books ON Sellings.Id_Book = Books.Id
GROUP BY 
 Id_Seller
) b 
  JOIN Sellers ON Sellers.Id = b.Id_Seller
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
01.04.2017, 02:07
Помогаю со студенческими работами здесь

Ведомость на выплату квартальной премии и премии за выслугу лет
Ведомость на выплату квартальной премии и премии за выслугу лет Введите фамилии сотрудников (не менее 20), для всех них укажите даты...

Регистрация продавца в Play
Создал бесплатное приложение, выложил всё нормально прошло. Теперь подходить к завершению платное приложение, решил зарегистрировать себя...

Как настроить интерфейс продавца-кассира?
Как настроить такой интерфейс https://www.cyberforum.ru/1c/thread794991.html стоит обурудование posyflex драйвера установлены ...

Разделение функционала программы на продавца и администратора
Здравствуйте. Нужно написать программу на с++. Функционал программы должен быть разделен на продавца и администратора, администратор может...

Как объединить все продажи продавца?
есть база .в запросе &quot;зарплата продавца&quot; нужно объединить одноименные имена продавцов так чтоб значение в поле&quot;выражение&quot; тоже...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru