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

Вниз

SQL-запрос. Неужели придется прогу писать?   Найти похожие ветки 

 
Grrey   (2002-03-20 23:17) [0]

Задача:
Есть таблица с полями:
Date_Time Date,
Counter number
Нужно представить информацию по месяцам. Т.е.
Месяц - Число (Sum(Counter))
Пробовал так:
SELECT UDFSUB_STR(DATE_TIME,3,11), SUM(COUNTER) FROM TEMP_TAB GROUP BY DATE_TIME;
Там просто дата если начинаеться с чисел (день) < 10, то SUB_STR нужно использовать с другими параметрами. Неужели никак нельзя запросами ограничиться?
Может кто поможет?


 
kaif ©   (2002-03-20 23:49) [1]

Создай таблицу YEAR_DATES с полями:
THE_MONTH INTEGER
THE_DAY INTEGER
THE_YEAR INTEGER
THE_DATE DATE
Не забудь индексы тоже.
Заполни ее соответствующими значениями на 10 лет (это всего 3650 записей), объединяй со своей таблицей в запросе типа
SELECT THE_MONTH, THE_DAY, SUM(Counter)
FROM YEAR_DATES, MYTABLE
WHERE YEAR_DATES.DATE_TIME = MYTABLE.DATE_TIME
GROUP BY THE_MONTH, THE_DAY
Все это работает очень быстро.
В IB6.0 можно лучшее решение придумать (хранимую процедуру, генерящую такой набор).


 
Фэ ©   (2002-03-21 01:23) [2]

Кстати, если добавить поля ПОЛУГОДИЕ, КВАРТАЛ, НЕДЕЛЯ, РАБОЧИЙ ДЕНЬ, и т.п. намного жизнь облегчается по выборке за нужный интервал


 
grrey   (2002-03-21 11:11) [3]

Cпасибо!


 
Lusha ©   (2002-03-21 12:33) [4]

А что в Interbase нет функции преобразования даты в строку необходимого формата? Неужели обязательно нужно "левую" таблицу заводить :(


 
Fay ©   (2002-03-22 01:39) [5]

Напиши UDF и всё.


 
DiggerAbstract   (2002-03-22 04:29) [6]

SELECT
MONTH(DATE_TIME),
DAY(DATE_TIME),
SUM(COUNTER)
FROM
TEMP_TAB
GROUP BY 1, 2


 
grrey   (2002-03-22 08:42) [7]

To Fay> Легче процедурку написать. Я уже все сделал, в принципе, конечно не сам!
To DiggerAbstract> А функции Month, Day, Sum я как понял всеже писать придеться! И они будут очень медленно работать!
Но все равно спасибо!


 
Fay ©   (2002-03-22 12:44) [8]

А напиши их так, чтоб работали побыстрее!
Как мысля?



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

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

Наверх




Память: 0.48 MB
Время: 0.012 c
14-32979
Стас
2002-03-04 08:32
2002.04.11
Исходники для работы с dBASE в Паскале


3-32689
Sergey_R
2002-03-21 10:00
2002.04.11
Логическая структура БД


4-33018
Landgraph
2002-02-12 13:32
2002.04.11
TStream


3-32661
AndDem
2002-03-18 16:31
2002.04.11
SQL-запрос. Проблема с пониманием возможностей SQL.


1-32766
I Need Help, please
2002-03-30 01:51
2002.04.11
Не могу сделать элементарную вещь!