|
|
|
Можно ли сделать такое одним запросом?
|
|||
|---|---|---|---|
|
#18+
Есть таблицы: master(ID) и detail(DetID,ID(FK),Code) Надо отобрать такие строки из Master, что не имеют в detail строк с определенным значением code.(1, к примеру) То, что я придумал, мне не очень нравится 1. Отбираю строки Master, имеющие detail где Code=1 2. Джойню master c результатом left Join c условием where DetId=0 Но, наверное, можно одним запросом это сделать, вот только как? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 21.10.2004, 13:48:39 |
|
||
|
Можно ли сделать такое одним запросом?
|
|||
|---|---|---|---|
|
#18+
Ну так и получается один большой сложный запрос. В чем проблема то ? :-) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 21.10.2004, 15:29:59 |
|
||
|
Можно ли сделать такое одним запросом?
|
|||
|---|---|---|---|
|
#18+
supertim , Да проблемы особой нет, это, в принципе, работает. Просто я знаю, тут есть люди, которые могут писать оригинальные запросы, вот и подумал - а вдруг есть более изящный способ. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 21.10.2004, 15:48:05 |
|
||
|
Можно ли сделать такое одним запросом?
|
|||
|---|---|---|---|
|
#18+
С удовольствием посмотрю, если кто нибудь предложит что нить поэффектнее (не путать с эффективнее). У меня пара-тройка-четверка таких запросов работает и давно. MS ACCESS 2000 + Oracle 8 (линкованные таблицы) - не жалуюсь. Пока ;-) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 21.10.2004, 15:53:45 |
|
||
|
Можно ли сделать такое одним запросом?
|
|||
|---|---|---|---|
|
#18+
select a from t where a not in (select a from t1 where b=1) (в акцессе будет медленно работать) = select t.a from t left join (select a from t1 where b=1) as t2 on t.a=t2.a where t2.a is null (не проверяя, но примерно так) Это? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 21.10.2004, 16:07:51 |
|
||
|
|

start [/forum/topic.php?fid=45&gotonew=1&tid=1670915]: |
0ms |
get settings: |
6ms |
get forum list: |
14ms |
check forum access: |
2ms |
check topic access: |
2ms |
track hit: |
29ms |
get topic data: |
9ms |
get first new msg: |
4ms |
get forum data: |
2ms |
get page messages: |
34ms |
get tp. blocked users: |
1ms |
| others: | 205ms |
| total: | 308ms |

| 0 / 0 |
