Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Максимальные значения в группах 
:(
    Опции темы
JustAStudent
Дата 19.9.2007, 19:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Есть таблица с шапкой вида: 
| doc_id | doc_datetime | doc_type | doc_name |

Записи в таблице остортированы в порядке возрастания дат.
Задача: вытянуть по одному названию дока каждого типа, созданного позже других (MAX(doc_datetime))
 smile 

Пытаюсь сделать это с помощью группировки:
Код

SELECT MAX(doc_datetime), doc_name
FROM table
WHERE ...
GROUP BY doc_type


Естественно, полученая таким образом максимальная дата не соответствует названию документа.
Подскажите как выкрутиться, плиз.
PM MAIL   Вверх
Akina
Дата 19.9.2007, 21:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


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


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

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



Цитата(JustAStudent @  19.9.2007,  20:24 Найти цитируемый пост)
Записи в таблице остортированы в порядке возрастания дат

Это не имеет никакого значения

Первым (вложенным) запросом нужно получить MAX(doc_datetime) для каждой группы:

Код

SELECT doc_type, MAX(doc_datetime) As MaxDateTime
FROM table
GROUP BY doc_type


А вот вторым (внешним) запросом получить название соотв. доки:

Код

SELECT table.doc_type, table.doc_name, query.MaxDateTime
FROM table
JOIN 
(
 SELECT doc_type, MAX(doc_datetime) As MaxDateTime
 FROM table
 GROUP BY doc_type
) As query
ON table.doc_type=query.doc_type AND table.doc_datetime=query.MaxDateTime
Тип JOIN в данном случае может быть совершенно любым. Однако если на внутренний или внешний запрос наложены условия отбора (WHERE) - следует выбрать правильный тип связывания (INNER, LEFT, RIGHT, OUTER, FULL).


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

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


Эксперт
***


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

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



Код

  select t.doc_type, t.doc_name, t.doc_datetime
  from table_docs t
  where t.doc_datetime = (select max(t1.doc_datetime) from table_docs t1 where t1.doc_type = t.doc_type)



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


Новичок



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

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



Большое спасибо. Получилось smile 
Вложеные запросы рулят  smile 
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


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

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


 




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


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

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