Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности

Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
|
11.12.2006, 13:36
|
|||
|---|---|---|---|
|
|||
интервал даты |
|||
|
#18+
Всем добрый день! Как в sybase определить интервал 30 рабочих дней, исключая субботу, воскресенье и праздники (например 8 марта....)? Спасибо. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
11.12.2006, 13:51
|
|||
|---|---|---|---|
интервал даты |
|||
|
#18+
rep_user wrote: > Как в sybase определить интервал 30 рабочих дней, исключая субботу, > воскресенье и праздники (например 8 марта....)? Завести табличку, в которой будут перечислены все дни с признаками "рабочий/выходной". Далее можно циклом... Posted via ActualForum NNTP Server 1.3 ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
11.12.2006, 13:55
|
|||
|---|---|---|---|
|
|||
интервал даты |
|||
|
#18+
А можно как то в процедуре? и как мне можно из системного календаря заполнить свою табличку, хотя бы субботы и воскресенья. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
11.12.2006, 14:25
|
|||
|---|---|---|---|
|
|||
интервал даты |
|||
|
#18+
Не можно, а нужно в процедуре(или функции). Ибо встроенных средств для вашего случая нет. Есть такая функция DOW, возвращает день недели. С помощью нее можно отфильтровать субботы и воскресенья. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
11.12.2006, 14:58
|
|||
|---|---|---|---|
интервал даты |
|||
|
#18+
ALTER FUNCTION "DBA"."F_AddNBankDays"( IN dbegin date, in ndays integer ) RETURNS date DETERMINISTIC BEGIN DECLARE cdateret date; DECLARE i integer; DECLARE n integer; DECLARE cn integer; SET cdateret = dbegin; SET n = 0; lbl: LOOP SET cdateret = dateadd(day,1,cdateret); IF DATEPART(weekday,cdateret) not in (1,7) THEN // если рабочий день, то проверяем или наша любимая страна мож сделала его віходнім SET cn = 0; SELECT count(*) INTO cn FROM "dba"."holiday_days" WHERE ( "dba"."holiday_days"."cdate" = cdateret ) AND ( "dba"."holiday_days"."ctype" = 1 ); IF cn = 0 THEN //рабочий SET n = n + 1; END IF; ELSE //суббота или воскресенье, но в нашей стране могет и рабочий быть SET cn = 0; SELECT count(*) INTO cn FROM "dba"."holiday_days" WHERE ( "dba"."holiday_days"."cdate" = cdateret ) AND ( "dba"."holiday_days"."ctype" = 2 ); IF cn > 0 THEN //рабочий SET n = n + 1; END IF; END IF; IF n = ndays THEN LEAVE lbl; END IF; END LOOP lbl; /* Type the function statements here */ RETURN cdateret; END ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
11.12.2006, 15:23
|
|||
|---|---|---|---|
|
|||
интервал даты |
|||
|
#18+
Мне надо под ASE ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|

start [/forum/topic.php?fid=55&mobile=1&tid=2012365]: |
0ms |
get settings: |
6ms |
get forum list: |
14ms |
check forum access: |
2ms |
check topic access: |
2ms |
track hit: |
37ms |
get topic data: |
7ms |
get forum data: |
2ms |
get page messages: |
34ms |
get tp. blocked users: |
1ms |
| others: | 207ms |
| total: | 312ms |

| 0 / 0 |
