Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Oracle > Функция PL/SQL


Автор: 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
    
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;

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

в направлении http://docs.oracle.com/cd/B28359_01/appdev.111/b28371/adobjcol.htm#BABBJBHD.
При этом стараемся не забыть про limit, то мало ли, запрос и миллиарды значений может вернуть.

Автор: Zloxa 16.11.2011, 09:29
Цитата(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;

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)