Главная страница
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.031 c
4-1162809133
Avokain
2006-11-06 13:32
2007.03.25
Посылка текста в активное окно(Edit) другого приложения


2-1172838073
LigthStone
2007-03-02 15:21
2007.03.25
ReleaseCapture


15-1172568253
ArtemESC
2007-02-27 12:24
2007.03.25
Сквозное кэширование и кэширование с обратной связью...


6-1160254533
H@ns
2006-10-08 00:55
2007.03.25
Маска и широковещательный адрес.


15-1172329940
CCil
2007-02-24 18:12
2007.03.25
Почему google стоит так не дешево?