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

Вниз

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

 
AndbyOne ©   (2002-08-22 10:19) [0]

Есть 2 таблицы:
PERS: и PERSLOG:
BKEY SDATETIME
RKEY BKEY
PKEY RKEY
PKEY
Мне надо отобрать те записи из PERS, которых нет в PERSLOG, т.е. те PERS.BKEY которых нет в PERSLOG.BKEY;
Я делаю, так:
SELECT
DISTINCT PERS.*
FROM
PERSLOG,
PERS
WHERE PERS.BRIGADEKEY != PERSLOG.BRIGADEKEY
ORDER BY PERS.BRIGADEKEY
и он отбирает все записи, вообще все. ЧТо делать?


 
SaS13 ©   (2002-08-22 10:23) [1]

SELECT DISTINCT *
FROM PERS
WHERE BRIGADEKEY NOT IN (SELECT BRIGADEKEY FROM PERSLOG)
ORDER BY BRIGADEKEY


 
Desdechado ©   (2002-08-22 10:29) [2]

учить матчасть!
У тебя для каждой записи из PERS выбираются все записи из PERSLOG, у которых ключ не совпал. Потом применяется DISTINCT, т.е. получается по одной такой записи. Итог - все записи из PERSLOG

select P.* from Pers P
where not exists( SELECT L.sdatetime FROM Perslog L
WHERE L.bkey = P.bkey)

или ХП



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

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

Наверх




Память: 0.47 MB
Время: 0.015 c
6-35837
Landgraph
2002-07-08 10:26
2002.09.12
Socket


3-35579
Viacheslav
2002-08-21 21:54
2002.09.12
Кэшированный TQuery.


1-35722
c0pYc@t
2002-08-30 12:47
2002.09.12
Добавление в PopupMenu


1-35642
Begin
2002-09-01 06:51
2002.09.12
Что то меня сегодня распирает вопросами .... :)


14-35896
kull
2002-08-19 12:03
2002.09.12
Чем free-bsd от linux отличается?