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

Вниз

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

 
kubik ©   (2002-04-19 00:10) [0]

Помогите написать SQL запрос для:
есть две таблици:
spisok info
|--|--|--|--| |--|----|
|id|c1|c2|c3| |id|name|
|--|--|--|--| |--|----|
| 1| 1| 0| 0| | 1|xxx1|
| 2| 0| 0| 0| | 2|xxx2|
| 3| 1| 1| 0| | 3|xxx3|
| 4| 2| 0| 0| | 4|xxx4|
| 5| 3| 0| 1| | 5|xxx5|
|--|--|--|--| |--|----|
поля c1,2,c3 в таблице spisok являются указателями на id в info
в итоге надо получить результируюшую выбору
| 1|xxx1|
| 3|xxx1|
| 3|xxx1|
| 4|xxx2|
| 5|xxx3|
| 5|xxx1|

можно ли такое сделать одним SQL запросом? мысли шлите на serg@ens.ru


 
Mambet   (2002-04-19 05:02) [1]

Попробуй так.

SELECT Spisok.ID, Info.Name FROM Spisok,Info WHERE Spisok.C1=Info.ID
UNION ALL
SELECT Spisok.ID, Info.Name FROM Spisok,Info WHERE Spisok.C2=Info.ID
UNION ALL
SELECT Spisok.ID, Info.Name FROM Spisok,Info WHERE Spisok.C3=Info.ID


 
Ph.D.Kot ©   (2002-04-19 10:29) [2]

а лучше еще так:
select Spisok.ID, Info.Name from (
SELECT Spisok.ID, Info.Name FROM Spisok,Info WHERE Spisok.C1=Info.ID
UNION ALL
SELECT Spisok.ID, Info.Name FROM Spisok,Info WHERE Spisok.C2=Info.ID
UNION ALL
SELECT Spisok.ID, Info.Name FROM Spisok,Info WHERE Spisok.C3=Info.ID
) ORDER BY Spisok.ID



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

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

Наверх




Память: 0.47 MB
Время: 0.015 c
3-49864
PepperLover
2002-04-19 11:50
2002.05.16
ADO - выбор стратегии


3-49885
Илья_____
2002-04-18 18:54
2002.05.16
Как получить номер строки DBGrid a, на которой стоит курсор


14-50111
Rammish
2002-04-01 15:13
2002.05.16
О программизме, программации и программоделании


1-49950
ah
2002-05-01 16:01
2002.05.16
Почему так length(chr(9)+chr(8)+chr(0)+... + chr(56)....)= пусто


3-49866
Dorosh
2002-04-15 15:23
2002.05.16
Polaris DbTreeView