Форум программистов, компьютерный форум, киберфорум
Microsoft Access
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
0 / 0 / 0
Регистрация: 19.06.2019
Сообщений: 8

Множественный if?

22.11.2020, 23:49. Показов 1616. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток! Потихоньку делаю курсач, уже сделал достаточно много. И тут дело дошло до элементарной вещи, но толи мой мозг, то ли количество знаний не позволяют реализовать её: есть таблица, состоящая из номера карты, процента скидки, типа карты и количества потраченных денег. Нужно в зависимости от того, сколько было потрачено выставить тип карты (например, если было потрачено до 1000 руб., то статус карты - "Обычная", если до 5000, то "Bronze", если до 8000 - "Silver", если до 15000 - то "Gold", а после 15000 - "Special"), а так же в зависимости от типа карты поставить процент скидки (таким же макаром). Подскажите, пожалуйста, как это сделать через запрос на обновление. Спасибо за внимание!
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.11.2020, 23:49
Ответы с готовыми решениями:

Множественный выбор
Здравствуйте, подскажите возможно ли проделать такую операцию: в таблице excel имеется поле, где записаны данные например - "Иванов,...

Множественный выбор
Добрый день! Помоги в решении следующего вопроса: есть ленточная форма, на ней поле со списком с примерно 15-ью значениями по...

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

12
431 / 239 / 86
Регистрация: 09.04.2018
Сообщений: 1,023
23.11.2020, 00:11
Лучший ответ Сообщение было отмечено sb112 как решение

Решение

sb112, это в зависимости от количества, второй по аналогии.

SQL
1
2
3
4
5
UPDATE Таблица1 
SET тип=iif(потрачено<=1000,"обычная", iif(потрачено BETWEEN 1000 AND 5000, "Bronze", 
iif(потрачено BETWEEN 5000 AND 8000, "Silver",
iif(потрачено BETWEEN 8000 AND 15000, "gold",
iif(потрачено>15000, "Special"  )))))
1
Мы один, давай на "ты"
3852 / 1395 / 346
Регистрация: 16.06.2016
Сообщений: 3,290
23.11.2020, 08:42
Цитата Сообщение от sb112 Посмотреть сообщение
Множественный if?
нет, тут должна быть таблица со значениями. Даже если и курсач.
0
3 / 3 / 0
Регистрация: 19.04.2020
Сообщений: 119
23.11.2020, 10:36
Используйте оператор Select Case в качестве альтернативы для использования ElseIf в операторе If... Then... Else
https://docs.microsoft.com/ru-... statements
0
Модератор
Эксперт MS Access
6231 / 2909 / 707
Регистрация: 12.06.2016
Сообщений: 7,839
23.11.2020, 11:20
Цитата Сообщение от lubashishka Посмотреть сообщение
Используйте оператор Select Case в качестве альтернативы для использования ElseIf в операторе If... Then... Else
И как это в запросе сделать предлагаете?
ТС ведь пишет:
Цитата Сообщение от sb112 Посмотреть сообщение
Подскажите, пожалуйста, как это сделать через запрос на обновление.
0
Модератор
Эксперт MS Access
6231 / 2909 / 707
Регистрация: 12.06.2016
Сообщений: 7,839
23.11.2020, 11:26
Цитата Сообщение от Kiriver Посмотреть сообщение
SQL
1
2
3
4
5
UPDATE Таблица1 
SET тип=iif(потрачено<=1000,"обычная", iif(потрачено BETWEEN 1000 AND 5000, "Bronze", 
iif(потрачено BETWEEN 5000 AND 8000, "Silver",
iif(потрачено BETWEEN 8000 AND 15000, "gold",
iif(потрачено>15000, "Special"  )))))
BETWEEN'ы лишние.
SQL
1
2
3
4
UPDATE Таблица1 
SET тип=
IIf(потрачено<=1000,"обычная",IIf(потрачено<=5000,"Bronze",
IIf(потрачено<=8000,"Silver",IIf(потрачено<=15000,"gold","Special"))))
1
Мы один, давай на "ты"
3852 / 1395 / 346
Регистрация: 16.06.2016
Сообщений: 3,290
23.11.2020, 11:59
SQL
1
2
3
4
5
6
UPDATE Таблица1 
SET тип = Switch(потрачено <= 1000, "обычная", _
                  потрачено <= 5000, "Bronze", _
                  потрачено <= 8000, "Silver", _
                  потрачено <= 15000, "gold", _
                  потрачено > 15000, "Special")
Добавлено через 49 секунд
но всё же
Цитата Сообщение от Панург Посмотреть сообщение
тут должна быть таблица со значениями.
1
 Аватар для Andrey-MSK
3349 / 2235 / 388
Регистрация: 14.08.2018
Сообщений: 7,557
Записей в блоге: 4
23.11.2020, 12:18
T-SQL
1
2
3
4
5
6
7
8
9
UPDATE Таблица1 
SET тип = 
(CASE 
  WHEN потрачено <= 1000 THEN "обычная"
  WHEN потрачено <= 5000 THEN "Bronze"
  WHEN потрачено <= 8000 THEN "Silver"
  WHEN потрачено <= 15000 THEN "gold"
  WHEN потрачено > 15000 THEN "Special"
END)
0
Модератор
Эксперт MS Access
6231 / 2909 / 707
Регистрация: 12.06.2016
Сообщений: 7,839
23.11.2020, 12:25
Цитата Сообщение от Andrey-MSK Посмотреть сообщение
CASE
Не зря Вы тег T-SQL поставили.

Ведь в обычном Access'овском SQL (Jet) такого не имеется.
0
 Аватар для Andrey-MSK
3349 / 2235 / 388
Регистрация: 14.08.2018
Сообщений: 7,557
Записей в блоге: 4
23.11.2020, 12:36
Capi, Вообще-то этот оператор входит в SQL-92, так что по идее должен поддерживаться MS Access.
0
Модератор
Эксперт MS Access
6231 / 2909 / 707
Регистрация: 12.06.2016
Сообщений: 7,839
23.11.2020, 12:47
Andrey-MSK,

В стандартном SQL Access - отсутствует.
0
604 / 127 / 45
Регистрация: 12.04.2015
Сообщений: 519
23.11.2020, 22:05
а как же функция Switch ?
0
Модератор
Эксперт MS Access
6231 / 2909 / 707
Регистрация: 12.06.2016
Сообщений: 7,839
23.11.2020, 22:18
glsn,

См. пост #7.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
23.11.2020, 22:18
Помогаю со студенческими работами здесь

Множественный JOIN
Коллеги, доброго времени суток! Есть исходные данные: ТК и Товар, нужно подятнуть ПОб. И есть 4 таблицы, из которых ПОб тянется в...

Множественный insert в Access - ?
Всем привет А что, в Access-е нельзя затолкать инсертом в таблицу более одной записи? Как в MSSQL, например? Типа так: insert into...

Множественный экспорт в Excel
есть запрос1 данные и есть запрос2 список людей связанный с ним в форме1 создал список на основе запрос2 For i = 0 To...

Множественный выбор с ограничением
Доброго времени суток В своей деятельности в основном работаю с Access 2003. в связи с чем хотел бы задать вопрос знатокам Access версий...

Множественный выбор в КомбоБоксе
День добрый.. Подскажите как можно добиться, чтобы в комбоБоксе можно было вибирать 2 значения т.е выбрали например Активный и Новый


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru