Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Выборка первой и последней записи за день, как выбрать? 
:(
    Опции темы
Spirit_FTZI2
Дата 28.10.2007, 19:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Всем привет!

А кто поможет справится с очередной проблемой?  smile 
Есть таблица:
=========================
ID  | Name |         date      |   time
=========================
1    | sergey | 16.10.2007 | 09:00:00
1    | sergey | 16.10.2007 | 09:12:00
1    | sergey | 16.10.2007 | 21:00:00
2    | denis   | 16.10.2007 | 12:00:00
2    | denis   | 16.10.2007 | 11:12:00
2    | denis   | 16.10.2007 | 18:00:00
1    | sergey | 17.10.2007 | 07:00:00
1    | sergey | 17.10.2007 | 09:56:00
1    | sergey | 17.10.2007 | 13:00:00
2    | denis   | 17.10.2007 | 12:41:00
2    | denis   | 17.10.2007 | 15:11:00
2    | denis   | 17.10.2007 | 18:47:00

То есть у нас таблица с логом посещений. Нужно получить за каждое число по каждому человеку первое и последнее посещение за сутки или хотябы вычислить первое и последнее посещение за конкретную дату... 

Можно ли получить чтото вроди этого:
1    | sergey | 16.10.2007 | 09:00:00 | 21:00:00
2    | denis   | 16.10.2007 | 12:00:00 | 18:00:00
1    | sergey | 17.10.2007 | 07:00:00 | 13:00:00
2    | denis   | 17.10.2007 | 12:41:00 | 18:47:00

Спасибо всем, кто откликнется!
PM MAIL   Вверх
Deniz
Дата 29.10.2007, 06:39 (ссылка) |   (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1251
Регистрация: 16.10.2004
Где: Новый Уренгой

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



Неплохо бы указать СУБД и типы полей.
Чтобы посчитать все это за период времени, нужно дату и время совокупить в одно поле.
Предположим что date и time не строковые поля, тогда за конкретную дату:
Код

select name, min(time), max(time) from table where date = <нужная дата> group by name

после того, как сделаешь поле с датой и временем немного подправь данный запрос.


--------------------
"Для того чтобы сделать шаг вперед, достаточно пинка сзади" (с)
PM ICQ   Вверх
Spirit_FTZI2
Дата 29.10.2007, 18:02 (ссылка)  | (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



через ADO компоненты конекчусь к SQL server.
Типы полей в принципе роли не играют, дата - datetime, время - строковое. Но ничего, время можно перевести в datetime (что я и делаю)... 

Спасибо за дату, а вот если нужно в одном запросе за несколько дат???
PM MAIL   Вверх
Deniz
Дата 30.10.2007, 06:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1251
Регистрация: 16.10.2004
Где: Новый Уренгой

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



Цитата(Spirit_FTZI2 @  29.10.2007,  21:02 Найти цитируемый пост)
Типы полей в принципе роли не играют
Как раз таки играют.

Сделаешь
Цитата(Deniz @  29.10.2007,  09:39 Найти цитируемый пост)
... нужно дату и время совокупить в одно поле.

Код

select
  t.Name,
  DAY(t.Date) as Day_Date,
  MONTH(t.Date) as Month_Date,
  YEAR(t.Date) as Year_Date,
  min(t.Date) as Min_DateTime,
  max(t.Date) as Max_DateTime
from Table t
where t.Date between <начало периода> and <конец периода>
group by t.Name, YEAR(t.Date), MONTH(t.Date), DAY(t.Date)
order by YEAR(t.Date), MONTH(t.Date), DAY(t.Date), t.Name

+ в помощь F1 DatePart


--------------------
"Для того чтобы сделать шаг вперед, достаточно пинка сзади" (с)
PM ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • Вопросы по SQL и вопросы по базам данных не связанные с Дельфи задавать здесь

FAQ раздела лежит здесь!


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

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


 




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


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

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