Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 0
Регистрация: 05.12.2016
Сообщений: 178

Изменять цену в определенный промежуток дат

23.05.2019, 15:57. Показов 466. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Люди прошу помощи. Есть 3 таблицы
Календарный тариф
Code
1
2
3
4
5
6
7
8
[Id]              INT  IDENTITY (1, 1) NOT NULL,
[НачалоСезона]    DATE NOT NULL,
[КонецСезона]     DATE NOT NULL,
[КатегориНомеров] INT  NOT NULL,
[Тариф]           INT  NOT NULL,
PRIMARY KEY CLUSTERED ([Id] ASC),
CONSTRAINT [FK_ТарифныйКалендарь_Тарифы] FOREIGN KEY ([Тариф]) REFERENCES [dbo].[Тарифы] ([IdТарифа]),
CONSTRAINT [FK_ТарифныйКалендарь_ТипНомера] FOREIGN KEY ([КатегориНомеров]) REFERENCES [dbo].[ТипНомера ([IdТипа])
ТипНомера
Code
1
2
3
4
5
    
[IdТипа]       INT            IDENTITY (1, 1) NOT NULL,
[Название]     NVARCHAR (50)  NOT NULL,
[ОписаниеТипа] NVARCHAR (250) NOT NULL,
PRIMARY KEY CLUSTERED ([IdТипа] ASC)
Номера гостиницы
Code
1
2
3
4
5
6
7
[IdНомера]               INT IDENTITY (1, 1) NOT NULL,
    [IdТипа]                 INT NOT NULL,
    [КоличествоМест]         INT NOT NULL,
    [СтоимостьВСутки]        INT NOT NULL,
    [Стоимость(ПоУмолчанию)] INT NOT NULL,
    PRIMARY KEY CLUSTERED ([IdНомера] ASC),
    CONSTRAINT [FK_НомераГостиницы_ТипНомера] FOREIGN KEY ([IdТипа]) REFERENCES [dbo].[ТипНомера] ([IdТипа])
Нужно с помощью запроса изменять ту стоимость номеров с той категорией номера и в тот промежуток дат которые указаны в таблице Календарный тариф.
Вот я пробую это делать с таким запросом, но у меня меняется стоимость у всех номеров со всеми категориями.
SQL
1
2
3
4
5
UPDATE НомераГостиницы SET СтоимостьВСутки = [Стоимость(ПоУмолчанию)] + [Стоимость(ПоУмолчанию)]*(Процент/100.0)
    FROM ТарифныйКалендарь, Тарифы
        WHERE НомераГостиницы.IdТипа = ТарифныйКалендарь.КатегориНомеров AND (НачалоСезона >= @DataZasel AND КонецСезона <=  @DataVisel)
        OR
        (НачалоСезона < @DataZasel AND КонецСезона > @DataVisel)
А если указанный промежуток не относится к промежутку указанного в таблице Календарный тариф нужно выполнять подобную процедуру
SQL
1
2
3
UPDATE НомераГостиницы SET СтоимостьВСутки = [Стоимость(ПоУмолчанию)]
    FROM ТарифныйКалендарь
        WHERE  НачалоСезона < @DataZasel AND КонецСезона >  @DataZasel
Кто поможет разобраться буду признательна.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
23.05.2019, 15:57
Ответы с готовыми решениями:

Показать все комнаты которые не заняты в заданный промежуток времени без наложения дат
Есть таблицы : `Order` `Room` Необходимо показать комнаты которые не заняты в заданный период, и чтобы не происходило...

Возможно ли сделать так, чтобы база сама очищалась через определенный промежуток времени
Скажите комрады, возможно ли задать такие параметры, чтобы база опустошалась через определенный интервал, и все данные из нее удалялись не...

Необходимо, если товар был продан более 3 раз, повысить цену на него на определенный процент
Имеется таблица продажи со столбцами: код_товара,количество_проданного,цена. Необходимо, если товар был продан более 3 раз, повысить цену...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
23.05.2019, 15:57
Помогаю со студенческими работами здесь

Промежуток дат
Мне нужна помощь чтобы сортировать новости с помощью 2 дат. 1 дата будет какая то часть база данных мне нужно узнать команду впадает ли он...

Вывести весь промежуток дат
Помогите плиз!Есть 2 компонента DateTimePicker в 1-м выбираем 1-ю дату во 2-м, 2-ю дату необходимо в ListBox вывесть весь промежуток дат в...

Вывести промежуток дат на форму
Возможно ли вывести промежуток вводимых дат из запроса на форму в поле? Если да, то как это можно сделать?

Вывод всех дат входящих в промежуток
В таблице1 поля Дата заезда и Дата выезда имеются даты. В Delphi в DateTimePicker1 и DateTimePicker2 заносится промежуток, надо вывести...

Вывести записи попадающие в промежуток дат
Нужно вывести записи попадающие в промежуток дат fdm.DSorgteh.DataSet:=fmain.ADOQuery1; adoquery1.SQL.Clear; ...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Управление камерой с помощью скрипта 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 На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru