Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Помогите сосавить SQL запрос

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
Fern
Гость





СообщениеДобавлено: Пн Сен 02 2002 18:40    Заголовок сообщения: Помогите сосавить SQL запрос Ответить с цитатой

Есть таблица afk :

+--------+------+
| title | id |
+--------+------+
| Oberon | 2004 |
| Oberon | 3150 |
| Oberon | 1210 |
| Kavin | 4060 |
+--------+------+

Как бы составить запрос чтобы он выводил :

title id
-------------------------------------
Oberon 2004, 3150, 1210
Kavin 4060

ну или на худой конец:

Oberon 200431501210

Заранее благодарю всех, кто взвалит на себя тяжкий груз ответа Wink
Вернуться к началу
swordfish



Зарегистрирован: 07.05.2002
Сообщения: 100
Откуда: Наб. Челны

СообщениеДобавлено: Вт Сен 03 2002 10:09    Заголовок сообщения: Re: Помогите сосавить SQL запрос Ответить с цитатой

Никак. Пиши хранимые проц. обрабатывай выборку ручками
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Programmer



Зарегистрирован: 20.07.2002
Сообщения: 7
Откуда: Rostov-on-Don

СообщениеДобавлено: Вт Сен 03 2002 10:18    Заголовок сообщения: Re: Помогите сосавить SQL запрос Ответить с цитатой

В Oracle я бы сделал так:

1. Объявим функцию
CREATE OR REPLACE function ReturnID
(inputTitle in varchar2)
return varchar2 is
cursor pr is
select to_char(id) from afk
where (title=inputTitle);
str1 varchar2(30);
str2 varchar2(30);
begin
open pr;
str1 := '';
str2 := '';

LOOP
FETCH pr into str1;
EXIT WHEN pr%NOTFOUND;
str2 := str2 || str1 || ',';
END LOOP;

--уберем лишнюю запятую
str2 := substr(str2,1,length(str2)-1);
return str2;

end;
/

2. Получим то, что нужно

select distinct(title), returnID(title) from afk
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Andy-C
Гость





СообщениеДобавлено: Ср Сен 04 2002 07:39    Заголовок сообщения: Re: Помогите сосавить SQL запрос Ответить с цитатой

SQL не вариант.
Но есть всякие примочки которые эмулируют
фокс/аксес что-то типа cross table
Delphi/Builder Decisin cube
в оракле...
Ну а ручками вообще Wink
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...