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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Помогите составить запрос. Выбор самой поздне даты, SQL ORACLE  
:(
    Опции темы
chiffa
Дата 21.1.2013, 16:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Всем добрый день. Стоит задача сделать запрос по трем таблицам, в последней из них есть много полей с датой  необходимо выбрать единственную запись в которой дата самая последняя. Делаю так:
Код



SELECT distinct a.num, b.surname,
       b.name, b.fname, c.date_time
   FROM info a, clip b, lip c 
   where a.status = 0 and b.code = a.id
  and a.num in ('1111', '2222')
  and c.num_no = a.mun_no and c.date_time is not null
    order by c.date_time DESC




то есть, я в первой таблице нахожу нужны мне номера, дальше из второй таблици я нахожу записи поля которых code соответствую id первой таблице. На данном этапе все работает супер, выводит 2 найденные записи с данными из 2х таблиц. Далее добавляю третию где есть есть информация о дате и тут размер результатов увеличивается до количества записей в третей таблице. То есть оно берет не первую запись, а все. Пытался сделать так:

Код


select * from 
  (
SELECT distinct a.num, b.surname,
       b.name, b.fname, c.date_time
   FROM info a, clip b, lip c 
   where a.status = 0 and b.code = a.id
  and a.num in ('1111', '2222')
  and c.num_no = a.mun_no and c.date_time is not null
    order by c.date_time DESC
)
where rownum=1;


при таком выводит правильную (самую позднее дату) из третей таблицы, но запись всего одна. Помогите правильно составить запрос. Буду признателен за помощь!!!
PM MAIL   Вверх
Akina
Дата 21.1.2013, 17:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


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


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

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



ну например
Код

select нужные поля
from
(select чё там надо from таблицы 1 и 2 со всеми ограничениями) as подзапрос1
join
(select max(дата), другие поля для установления соответствия from таблица 3) as подзапрос 2
on (поля из подзапроса 1 = поля из подзапроса 2)



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

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


Опытный
**


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

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



Спасибо за ответ! А что подразумевается под "подзапрос1" и "подзапрос2"...
PM MAIL   Вверх
Arantir
Дата 21.1.2013, 17:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Рыбак без удочки
**


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

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



chiffa, псевдоним. Ну типа как переменная, чтобы вот там чуть ниже можно было написать "подзапрос1.какоетополе = подзапрос2.какоетополе"

Это сообщение отредактировал(а) Arantir - 21.1.2013, 17:47


--------------------
interface Жопа {
    // ATTENTION: has to be implemented by every class of the project for proper project work
}
PM   Вверх
chiffa
Дата 21.1.2013, 18:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Че то я намного запустался, как я понял так:
Код

select *
from
(select distinct a.num, b.surname,
       b.name, b.fname, c.date_time from info a, clip b where a.status = 0 and b.code = a.id
  and a.num in ('1111', '2222')) as table1
join
(select max(c.date_time) from lip c) as table2
on (table2.num_no = table1.mun_no)


но оно не работает, значит где то косяк...
PM MAIL   Вверх
Arantir
Дата 21.1.2013, 18:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Рыбак без удочки
**


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

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



У вас в запросе, который вы назвали "table1" нету в выбранных поля "num_no", которое вы ниже пытаетесь использовать. Так же и для "table2".
Это псевдоним запроса, а не имени таблицы. Он нужен, например, если поля в разных таблицах одинаково называются.
Если вы и так приписываете имена таблиц у полям, то можете точно так же поступить после ON, без использования псевдонимов.


--------------------
interface Жопа {
    // ATTENTION: has to be implemented by every class of the project for proper project work
}
PM   Вверх
Zloxa
Дата 22.1.2013, 01:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Цитата(chiffa @  21.1.2013,  17:51 Найти цитируемый пост)
 необходимо выбрать единственную запись в которой дата самая последняя.

забрать всего одно значение?
похоже тут самое место скаляру
Код

SELECT distinct a.num, b.surname,
       b.name, b.fname, (select max(c.date_time) from lip c where  c.num_no = a.mun_no and c.date_time is not null) date_time
   FROM info a, clip b
   where a.status = 0 and b.code = a.id
  and a.num in ('1111', '2222')
    order by 5 DESC


distinct тут действительно нужен?

Это сообщение отредактировал(а) Zloxa - 22.1.2013, 01:24


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
chiffa
Дата 22.1.2013, 10:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Zloxa, огромное спасибо! То что нужно!!!
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Составление SQL-запросов | Следующая тема »


 




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


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

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