Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Функция PL/SQL 
V
    Опции темы
dolby
Дата 14.11.2011, 22:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 31
Регистрация: 23.2.2008
Где: Минск

Репутация: нет
Всего: нет



Помогите, пожалуйста, никак не могу разобраться.
Мне необходимо сделать так, чтобы в MAS_ID переписать ID_суден, с учетом того, что запрос может вернуть не одно значение, а несколько. Подскажите хотя бы в каком направлении копать или помогите подправить запрос.

Код

create or replace function "SUDNO_FIND"
(numb in NUMBER,
port in VARCHAR2,
date_pogr in DATE)
return NUMBER
is
    
Gr_sud number;
Result number;
Row_numb number;
TYPE massiv IS TABLE OF INTEGER(38,0) INDEX BY BINARY_INTEGER;
MAS_ID massiv;
Ничего exception;
    
begin

    SELECT ID_судна INTO MAS_ID(1)
    FROM Рейс
    WHERE ((ДАТА_ОКОНЧАНИЯ = date_pogr) AND (Порт_конца = port));


Row_numb := Mas_id.Count;
RETURN Row_numb;
END;


Это сообщение отредактировал(а) dolby - 14.11.2011, 22:21
PM MAIL ICQ   Вверх
Zloxa
Дата 14.11.2011, 23:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 37
Всего: 161



Цитата(dolby @  14.11.2011,  22:21 Найти цитируемый пост)
в каком направлении копать

в направлении bulk collect.
При этом стараемся не забыть про limit, то мало ли, запрос и миллиарды значений может вернуть.


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
Zloxa
Дата 16.11.2011, 09:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 37
Всего: 161



Цитата(dolby @  14.11.2011,  22:21 Найти цитируемый пост)
Мне необходимо сделать так, чтобы в MAS_ID переписать ID_суден, с учетом того, что запрос может вернуть не одно значение, а несколько.

чета я ответил не подумав а нужны ли вам коллекции...
Если вам надо вернуть лишь количество, его и надо считать.
Код

create or replace function "SUDNO_FIND"
(numb in NUMBER,
port in VARCHAR2,
date_pogr in DATE)
return NUMBER
is
  result number;
begin
    SELECT count(*) INTO result
    FROM Рейс
    WHERE ((ДАТА_ОКОНЧАНИЯ = date_pogr) AND (Порт_конца = port));
    RETURN result;
END;



--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Oracle"
Zloxa
LSD

Данный раздел предназначен для обсуждения проблем с Oracle Database, другие продукты Oracle здесь не обсуждаются. Просьба при создании темы, придерживаться следующих правил:

  • при создании темы давайте ей осмысленное название, описывающее суть проблемы
  • указывайте используемую версию базы, способ соединения и язык программирования
  • при ошибках обязательно приводите код ошибки и сообщение сервера
  • приводите код в котором возникла ошибка, по возможности дайте тестовый пример демонстрирующий ошибку
  • при вставке кода используйте соответсвующие теги: [code=sql] [/code] для подсветки SQL и PL/SQL кода, [code=java] [/code] - для Java, и т.д.

  • документация по Oracle: 9i, 10g, 11g
  • книги по Oracle можно поискать здесь
  • действия модераторов можно обсудить здесь

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Zloxa, LSD.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Oracle | Следующая тема »


 




[ Время генерации скрипта: 0.0922 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.