Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.10.27;
Скачать: CL | DM;

Вниз

Как вычесть праздничные даты?   Найти похожие ветки 

 
sash2   (2003-10-07 14:24) [0]

Есть база.
В ней есть поля "ночало отпуска" и "дата окончания отпуска".
[b]Скажите пожалуйста, как из периода отпуска вычесть праздничные даты???[/b]
Например, если отпуск с 6 января(ночало отпуска) по 1 февраля(дата окончания отпуска). Встречается праздник 7 января. Если отпуск с 1 мая по 23 мая. Встречаетс 1, 2, 9 мая.


 
Johnmen ©   (2003-10-07 14:32) [1]

В потрепаться, там доходчиво объяснят :))))))))))))0


 
sniknik ©   (2003-10-07 14:42) [2]

примерный алгоритм, нужна табличка с датами праздников, начинаеш расчитывать отпуск с "ночало отпуска" и добавляеш по дню предварительно сверившись с вхождением в табличку с датами празников и выходными (естественно) если входит то следуюший день без изменений периода нет то минус "период отпуска", и так до нуля периода, текущая дата и будет искомой.

только смотри осторожнее, в связи с большим количеством праздников, можно проскочить год и зациклится. ;о))


 
Akni ©   (2003-10-07 14:44) [3]

Что значит "вычесть праздничные даты"?
Если под этим подразумевается подсчет именно РАБОЧИХ дней в отпуске, то алгоритм примерно след.:
1. завести еще одну таблицу, в которой хранить даты праздников (учитывая случаи попадания праздника на выходной день и переноса его на след. рабочий)
2. посчитать полное время отпуска: дата конца отпуска - дата начала + 1
3. пройтись в цикле от начала до конца отпуска и проверять, попадает ли на тек. дату выходной/праздничный день. Ели да, то отнимать 1 от полного времени отпуска.

Или под вычитанием праздничных дат что-то другое понималось?


 
MsGuns ©   (2003-10-07 15:57) [4]

Все решается запросом с конструкцией WHERE (dt BETWEEN <Дата начала> AND <Дата конца>) AND NOT IN (SELECT), где встроенный селест выбирает праздники, которые, ессно, должны быть в какой-то таблице-справочнике.



Страницы: 1 вся ветка

Текущий архив: 2003.10.27;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.036 c
14-89545
Думкин
2003-10-08 05:15
2003.10.27
С Днем рождения! 8 октября.


7-89628
Sheng
2003-08-14 23:03
2003.10.27
Каталог Винды


1-89260
AlexanderSK
2003-10-14 16:16
2003.10.27
Одновременный доступ к файлу.


1-89269
Sergey SP
2003-10-14 13:40
2003.10.27
работа с Word через OLE


7-89593
miguel1
2003-07-08 17:51
2003.10.27
Отправка факсов и голосовых сообщений через модем