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

Вниз

Подскажите SQL запрос   Найти похожие ветки 

 
d@nger   (2010-04-26 12:33) [40]

структура таблиц следующая:
таблица call_log
ID     - ключ
ORG_ID - ключ организации клиента из таблицы clients.id
CALL_DATE - дата
TEXT - текст
ORG_NAME - текст

в таблице clients много полей... но поле ID точно есть... тоже ключевое...


 
d@nger   (2010-04-26 12:37) [41]

вобщем вот в таком виде ошибки нет.. но результат просто выводит все записи...
select c.*, org_name, text from call_log c
left join
(select a.org_id, max(a.call_date) max_date from call_log a
left join clients g on (call_date between "01.04.2010" and "30.04.2010") and a.org_id = g.id
group by a.org_id) b on c.id = b.org_id


 
test ©   (2010-04-26 12:42) [42]

select * from call_log c
left join
(select a.org_id, max(a.call_date) max_date from call_log a
left join clients b on ((call_date>="01.04.2010")and(call_date<="30.04.2010")) and a.org_id = b.id
group by a.org_id) b on c.org_id = b.org_id and c.call_date = b.max_date


Я думал что org_id и есть идентификатор, тогда тебе связь нужна по всем полям результирующего набора


 
test ©   (2010-04-26 12:47) [43]

d@nger   (26.04.10 12:37) [41]
Тут ошибка, он по разным полям связь делает, в смысле он делает связь по ключу первой таблицы с ключем второй таблицы.


 
d@nger   (2010-04-26 12:49) [44]


> test ©   (26.04.10 12:42) [42]

этот запрос тоже выдает просто все записи таблицы


 
test ©   (2010-04-26 13:04) [45]

d@nger   (26.04.10 12:49) [44]
Не может быть чтобы все строки в таблице соответствовали c.org_id = b.org_id and c.call_date = b.max_date


 
d@nger   (2010-04-26 13:12) [46]


> Не может быть чтобы все строки в таблице соответствовали
> c.org_id = b.org_id and c.call_date = b.max_date


возможно это условие как то игнорируется фаербердом


 
Anatoly Podgoretsky ©   (2010-04-26 13:14) [47]

> d@nger  (26.04.2010 12:37:41)  [41]

Видимо org_id, call_date и все записи только в интервале "01.04.2010" and "30.04.2010"


 
d@nger   (2010-04-26 13:18) [48]


> идимо org_id, call_date и все записи только в интервале
> "01.04.2010" and "30.04.2010"


ID ORG_ID CALL_DATE       TEXT    ORG_NAME
97 59 18.03.2010             gregreg         Агропромипорт Холдинг
98 59 13.04.2010     ergregerg         Агропромипорт Холдинг
99 59 21.04.2010    regergerg       Агропромипорт Холдинг
100 59 28.04.2010        erger65ty546 Агропромипорт Холдинг
101 59 20.05.2010    6356356fvgfd Агропромипорт Холдинг
102 59 29.05.2010     ergerger          Агропромипорт Холдинг
103 58 14.04.2010         retкуце ецкецкуе Администрация города
104 58 15.04.2010    цукецкуе ку5435        Администрация города
105 58 22.04.2010        е45243525епкупуц Администрация города

в поле TEXT я так просо аброкадабру написал на время разработки


 
test ©   (2010-04-26 13:19) [49]

d@nger   (26.04.10 13:12) [46]
Это правило по которому он связывает, он его игнорировать не может.
Измени
select * from call_log c
На
select c.org_id, b.org_id, c.call_date, b.max_date from call_log c
И посмотри построчно.


 
Anatoly Podgoretsky ©   (2010-04-26 13:21) [50]

> d@nger  (26.04.2010 13:12:46)  [46]

Да как он посмел


 
d@nger   (2010-04-26 13:23) [51]

вот сейчас выдал вот это :

ORG_ID ORG_ID1 CALL_DATE       MAX_DATE
59                  18.03.2010
59                 13.04.201 0
59                  21.04.2010  
59                  28.04.2010
59                  20.05.2010
59             59            29.05.2010      29.05.2010
58                     14.04.2010
58               15.04.2010
58         58            22.04.2010      22.04.2010


пустые значения null


 
d@nger   (2010-04-26 13:28) [52]

т.е. там где ORG_ID1 не пустое правильные ответы, теперь осталось только отсеять строки где оно равно null


 
test ©   (2010-04-26 13:39) [53]

d@nger   (26.04.10 13:23) [51]

select * from call_log c
right join
(select a.org_id, max(a.call_date) max_date from call_log a
left join clients b on ((call_date>="01.04.2010")and(call_date<="30.04.2010")) and a.org_id = b.id
group by a.org_id) b on c.org_id = b.org_id and c.call_date = b.max_date


Помойму все дело в right join/left join.


 
d@nger   (2010-04-26 15:14) [54]


>
> Помойму все дело в right join/left join.


Ураа! действительно ... все заработало как надо.. спасибо огромное TEST ... намучились же вы со мной.. еще раз спасибо от души!


 
test ©   (2010-04-26 15:28) [55]

d@nger   (26.04.10 15:14) [54]
Пожалуйста. Заодно сам обновил знания SQL.


 
Кщд ©   (2010-04-26 17:45) [56]

test ©   (26.04.10 13:39) [53]
call_date>="01.04.2010"
1. нет alias
2. строка вместо даты
3. left join вместо join
4. последнюю запись на дату принято искать по индексу, а не агрегированием

плохие-плохие советы...


 
test ©   (2010-04-26 17:47) [57]

Кщд ©   (26.04.10 17:45) [56]
Берешь и сам помогаешь.


 
d@nger   (2010-04-26 19:21) [58]

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


 
d@nger   (2010-04-26 19:38) [59]

попробовал по совету Кщд заменить right join/left join на просто join ... и о чудо все стало работать как надо... еще убрал пару условий не влияющих на результат... итоговый результат следующий:
select c.id, c.org_id, c.call_date, c.org_name, c.text from call_log c
join
(select a.org_id, max(a.call_date) max_date from call_log a
join call_log b on a.call_date between "01.03.2010" and "30.03.2010"
group by a.org_id) d on c.call_date = d.max_date



> 4. последнюю запись на дату принято искать по индексу, а
> не агрегированием

дело в том что дату пользватель вводит самостоятельно, поэтому поиск по ключевому полю не подходит.. или вы имеете ввиду что то другое...


 
sniknik ©   (2010-04-26 20:25) [60]

> и о чудо все стало работать как надо...
до первых повторов дат


 
sniknik ©   (2010-04-26 20:36) [61]

вот так попробуй
select org_id, call_date, text, org_name from call_log
where id in (
 select max(id) from call_log a
 inner join (
   select org_id, max(call_date) as call_date from call_log where call_date between "01.05.2010" and "30.05.2010" group by org_id
 ) b on a.org_id=b.org_id and a.call_date=b.call_date
 group by a.org_id) c


не будет зависеть от того
> что id и call_date одновременно возрастают.

главное чтобы id был уникальным. и если в одной группе org_id будет 2 одинаковые даты то возьмется с большим id, хотя это неважно но что то же нужно выбирать.
в твоем запросе ([59]) даже не в диапазоне org_id, а во всем периоде совпадение дат приведет к дублям/"триблям"/"и т.д.блям" ;)


 
d@nger   (2010-04-26 20:46) [62]


> sniknik ©   (26.04.10 20:36) [61]
>
> вот так попробуй

тоже все работает нормально...


 
d@nger   (2010-04-26 20:48) [63]


> главное чтобы id был уникальным

id ключевое автоинкрементное поле..


 
sniknik ©   (2010-04-26 20:49) [64]

> тоже все работает нормально...
тогда оставь эту, эта больше учитывает...
вот забей в приведенном примере данных у всех записей одну и туже дату и проверь обе процедуры.


 
sniknik ©   (2010-04-26 20:50) [65]

> процедуры.
блин, запроса.


 
d@nger   (2010-04-26 21:00) [66]


> вот забей в приведенном примере данных у всех записей одну
> и туже дату и проверь обе процедуры.

да... твоя корректно отработала...  предыдущая показала дубли

спасибо sniknik


 
Кщд ©   (2010-04-27 07:10) [67]

>test ©   (26.04.10 17:47) [57]
это что, приказ?)
мой пост был Вам, а не автору
если считаете мои советы дурными - не следуйте им)



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

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

Наверх




Память: 0.57 MB
Время: 0.063 c
4-1236197897
d@vinchi
2009-03-04 23:18
2010.08.27
Как получить зарегистрированные в системе TAPI-линии


3-1243786232
Serjio77
2009-05-31 20:10
2010.08.27
Ошибка отображения данных в результате sql запроса в BDE


15-1271018147
@!!ex
2010-04-12 00:35
2010.08.27
Lab степень отличия цветов друг от друга


2-1273335534
alexandr
2010-05-08 20:18
2010.08.27
использование потоков для передачи строковой информации


2-1271760916
Irisss
2010-04-20 14:55
2010.08.27
Панель иконок





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский