Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Попадание в интервал 
:(
    Опции темы
belka0107
Дата 13.6.2010, 20:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 34
Регистрация: 31.10.2006

Репутация: нет
Всего: нет



Здравствуйте! Помогите разобрать с небольшой пробелемой. Есть даты:

01.06.10 13:10
29.05.10 01:43

и есть периоды:
05:00:00 - 13:00:00
13:00:00 - 21:00:00
21:00:00 - 05:00:00

Надо узнать в какие интервалы попали вышеуказанные даты?

PM MAIL   Вверх
nworm
Дата 13.6.2010, 22:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 502
Регистрация: 22.10.2005

Репутация: 4
Всего: 8



Узнаёшь для каждой даты время и проверяешь... Всё.
PM MAIL WWW   Вверх
Akina
Дата 17.6.2010, 08:04 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20570
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 20
Всего: 453



Период, переходящий полночь, следует разделить на два.
Скажем, в формате БД это будет так:

Таблица Periods
Цитата

pStart pEnd pNum
00:00  04:59  3
05:00  12:59  1
13:00  20:59  2
21:00  23:59  3
Запрос
Код

SELECT pNum
FROM Periods
WHERE Time(:myDateTime) BETWEEN pStart AND pEnd



--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
sibedir
Дата 17.6.2010, 16:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 10
Регистрация: 5.12.2008
Где: Россия Алтайский кр. г.Барнаул

Репутация: нет
Всего: нет



Не знаю как в БД, а в обычном программировании ничего делить не надо.
1. t1 = 05:00:00
    t2 = 13:00:00
    t3 = 21:00:00
2. Выделяешь из даты и времени время (t)
3.
Код

Если t < t1 то
      1
иначе
      Если t < t2 то
            2
      иначе
            Если t < t3 то
                  3
            иначе
                  1


Или еще проще
1. t1 = 08:00:00
    t2 = 16:00:00
2. Выделяешь из даты и времени время (t)
3. t = t - (05:00:00)
4. 
Код

Если t < t1 то
      2
иначе
      Если t < t2 то
            3
      иначе
            1

PM MAIL   Вверх
Akina
Дата 17.6.2010, 18:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20570
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 20
Всего: 453



Цитата(sibedir @  17.6.2010,  17:54 Найти цитируемый пост)
в обычном программировании ничего делить не надо

Есссно... но где универсальность?


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Алгоритмы"

maxim1000

Форум "Алгоритмы" предназначен для обсуждения вопросов, связанных только с алгоритмами и структурами данных, без привязки к конкретному языку программирования и/или программному продукту.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, maxim1000.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Алгоритмы | Следующая тема »


 




[ Время генерации скрипта: 0.1167 ]   [ Использовано запросов: 20 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.