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

Вниз

Как добавить поле в результат?   Найти похожие ветки 

 
Ш-К   (2007-03-04 01:33) [0]

Таблица table1(name, value).
name, value не уникальны.

Имею запрос, который меня почти устраивает:

select name, value from table1
where value in
   (select value from table1
      where name in ("name0", "name1", "name2", "name3"));


Т.е. в подзапросе я получаю все value, которые соответствуют константам ("name0", "name1", "name2", "name3"). Их может быть больше 4.
А потом, из той же таблицы все записи, соответствующие полученным value.
Мне нужно переписать запрос так, чтобы в результат добавилось еще поле, которое отобразит константу "name0", "name1" ...


 
Ш-К   (2007-03-04 01:52) [1]

Переформулирую.

select name, value
from table1
where name in ("name0", "name1", "name2", "name3")

это я получаю такой результат:
"name0" 132
"name0" 1244
"name1" 232435
"name1" 43
"name2" 324324
"name3" 2345
"name3" 34

А потом, для каждого value вывести не только все его name, но и базовый name в отдельном поле.
Все в одном запросе.


 
Anatoly Podgoretsky ©   (2007-03-04 07:52) [2]

> Ш-К  (04.03.2007 01:52:01)  [1]

Что такое базовое name


 
Ш-К   (2007-03-04 10:03) [3]

Базовое имя - это константа, по которой идет запрос:
"name0", "name1", "name2", "name3".

Т.е., если бы я выполнял запрос из одной константы, что-то типа:

select "name0", name, value from table1
where value in
(select value from table1
  where name in ("name0"));


Результат, отвечал бы задаче.
Что делать, когда несколько базовых имен?


 
Desdechado ©   (2007-03-04 17:59) [4]

Не понял, чем тебе name0 из поля name не базовый?


 
Ш-К   (2007-03-04 21:09) [5]

Потому что оно одно. А мне нужно и для "name1", "name2", "name3".

Вот так, только без Union:

select "name0", name, value from table1
where value in
(select value from table1
 where name in ("name0"))
union
select "name1", name, value from table1
where value in
(select value from table1
 where name in ("name1"))
union
select "name2", name, value from table1
where value in
(select value from table1
 where name in ("name2"))
union
select "name3", name, value from table1
where value in
(select value from table1
 where name in ("name3"))


 
Desdechado ©   (2007-03-04 21:21) [6]

SELECT name AS basovij_name, name, value
FROM Table1...

Или объясни понятнее свой "базовый". Это "опорный" или "из базы"? Или это эротическая фантазия, невоспроизводимая словами?


 
Ш-К   (2007-03-05 02:14) [7]


> Базовое имя - это константа, по которой идет запрос:
> "name0", "name1", "name2", "name3".


 
Ш-К   (2007-03-05 02:44) [8]

Ладно, забыли все.

Объясняю сначала с правильными словами.

Есть запрос:
select name, value from table1
where value in
(select value from table1
 where name in ("name0"));


который выдает результат:
a, 1
a, 2
b, 1
c, 3

Есть другой запрос:
select name, value from table1
where value in
(select value from table1
 where name in ("name1"));


Который выдает другой результат.
a, 1
f, 5
d, 1
c, 3

Мне надо объединить эти два результата. Но только добавить поле к каждой записи. Чтобы было видно, по какому критерию я их выбирал.

name0, a, 1
name0, a, 2
name0, b, 1
name0, c, 3
name1, a, 1
name1, f, 5
name1, d, 1
name1, c, 3

Запрос
select name, value from table1
where value in
(select value from table1
  where name in ("name0", "name1", "name2", "name3"));

Выдает то, что надо, только без указания: "name0", "name1", "name2", "name3". И выполняется он насколько секунд.

Если я сделаю:
select "name0", name, value from table1
where value in
(select value from table1
where name in ("name0"))
union
select "name1", name, value from table1
where value in
(select value from table1
where name in ("name1"))
union
...

Будет выполняться несколько часов. Етих слов("name0", "name1", "name2", "name3") больше 1000.


 
ЮЮ ©   (2007-03-05 03:53) [9]

Для начала замени union на union all


> Етих слов("name0", "name1", "name2", "name3") больше 1000.

Неужели пользователь столько вбивает их с клавиатуры? Или откуда они у тебя?
Это к тому, что если бы они лежали в отдельной таблице БД, то не надо было бы 1000 union, а хватило бы одного запроса


 
ЮЮ ©   (2007-03-05 03:56) [10]

Для начала замени union на union all


> Етих слов("name0", "name1", "name2", "name3") больше 1000.

Неужели пользователь столько вбивает их с клавиатуры? Или откуда они у тебя?
Это к тому, что если бы они лежали в отдельной таблице БД, то не надо было бы 1000 union, а хватило бы одного запроса


 
ЮЮ ©   (2007-03-05 03:58) [11]

Для начала замени union на union all


> Етих слов("name0", "name1", "name2", "name3") больше 1000.

Неужели пользователь столько вбивает их с клавиатуры? Или откуда они у тебя?
Это к тому, что если бы они лежали в отдельной таблице БД, то не надо было бы 1000 union, а хватило бы одного запроса


 
ЮЮ ©   (2007-03-05 04:17) [12]

Сорри, я не виноват, это всё DM-Client - виснет при отправке ответа


 
Ш-К   (2007-03-05 04:23) [13]

SELECT t.name, table1.name, table1.value
FROM table1 INNER JOIN
(SELECT table1.name, table1.value
FROM table1
WHERE table1.name In ("name0","name1","name2","name3")) AS t
On table1.value=t.value

Всем спасибо.



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

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

Наверх




Память: 0.5 MB
Время: 0.042 c
15-1172574124
DrDe
2007-02-27 14:02
2007.03.25
Delphi7, компи.....


15-1172479233
vajo
2007-02-26 11:40
2007.03.25
Проводник тормозит в сети


1-1170348097
Dreamse
2007-02-01 19:41
2007.03.25
Запуск программы от имени другого пользователя


15-1172575642
Vlad Oshin
2007-02-27 14:27
2007.03.25
Сломал флешку, пополам, не читается. Прочитать как-то реально?


4-1163149202
Natalex
2006-11-10 12:00
2007.03.25
Запуск компоненты TService