Главная страница
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.03 c
3-1167309164
evgen1
2006-12-28 15:32
2007.03.25
frReport1.Pages.Count=0?


15-1172667903
Knight
2007-02-28 16:05
2007.03.25
DMClient и прокси в настройках обозревателя... как вылечить?


1-1170164319
whitebarin
2007-01-30 16:38
2007.03.25
Как программно отключить Falsh накопитель?


3-1167194049
merko$
2006-12-27 07:34
2007.03.25
Как прочитать файл на удаленном ПК


15-1172172456
Cyrax
2007-02-22 22:27
2007.03.25
Дружественные методы и классы в C#