Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.05.23;
Скачать: CL | DM;

Вниз

Функции возвращающие набор данных в Оракле   Найти похожие ветки 

 
}|{yk ©   (2004-04-27 13:26) [0]

Что-то не совсем ясно как их создавать
Вот кусок кода
declare
COLUMN_NAME varchar2(32);
COLUMN_TYPE varchar2(32);

type t_TABLE_COLUMNS_REC IS RECORD (
COLUMN_NAME varchar2(32),
COLUMN_TYPE varchar2(32)
);
type t_TABLE_COLUMNS_REF is REF CURSOR return t_TABLE_COLUMNS_REC;

cursor COLUMNS_TABLE is
select a.column_name,a.data_type from all_tab_columns a
where UPPER(a.table_name)=UPPER("cust1")
and a.owner="CES";
begin
open COLUMNS_TABLE;
 loop
 FETCH COLUMNS_TABLE INTO COLUMN_NAME,COLUMN_TYPE;
 exit when COLUMNS_TABLE%NOTFOUND;
end loop;
close COLUMNS_TABLE;  
end;

А как это преобразовать в функцию?


 
Курдль ©   (2004-04-27 13:28) [1]

Мы тут недавно дискутировали про ref-cursor-ы. Там все написано.


 
Vlad ©   (2004-04-27 13:28) [2]


> }|{yk ©   (27.04.04 13:26)  

Ну и где ты тут заметил что возвращается курсор ?
Если хочешь возвращать курсор  на клиента, читай про REF CURSOR


 
}|{yk ©   (2004-04-27 13:39) [3]

А так

declare
type t_TABLE_COLUMNS_REF is REF CURSOR;
tables_cols t_TABLE_COLUMNS_REF;
begin
open tables_cols for
select a.column_name,a.data_type from all_tab_columns a
where UPPER(a.table_name)=UPPER("cust1")
and a.owner="CES";
end;

курсор клиенту возвращается?


 
Vlad ©   (2004-04-27 13:46) [4]


> }|{yk ©   (27.04.04 13:39) [3]
> А так

Не нужно гадать на кофейной гуще, почитай доки, там все написано.
Вкратце так: функция должна возвращать значение типа Ref Cursor.
Вот и создай такую функцию.


 
}|{yk ©   (2004-04-27 13:51) [5]

FUNCTION GETTABLECOLUMNS(
p_Table_Name all_tab_columns.table_name%TYPE,
p_Owner all_tab_columns.owner%TYPE
)
return t_TABLE_COLUMNS_REF is
type t_TABLE_COLUMNS_REF is REF CURSOR;
tables_cols t_TABLE_COLUMNS_REF;
begin
open tables_cols for
select a.column_name,a.data_type from all_tab_columns a
where UPPER(a.table_name)=UPPER(p_Table_Name)
and a.owner=p_Owner;

end;

Но тип вед должен быть объявлен до создания функции. Не пойму чего-то я. Инвалидный объект получается


 
Vlad ©   (2004-04-27 13:54) [6]


> }|{yk ©   (27.04.04 13:51) [5]

Во-первых эта функция ничего не возвращает.
Во-вторых тип должен быть объявлен до объявления функции, например в спецификации пакета


 
Курдль ©   (2004-04-27 14:15) [7]

Действующий простой пример:

create or replace package TEST_PACKAGE is
 type TMyRefCursor is ref cursor return PR_SUBJECTS%ROWTYPE;
 function TEST_FUNCTION return TMyRefCursor;
end TEST_PACKAGE;
/

create or replace package body TEST_PACKAGE is
 function TEST_FUNCTION return TMyRefCursor is
 rc TMyRefCursor;
 begin
   open rc for select * from PR_SUBJECTS;
   return rc;  
 end;
end TEST_PACKAGE;
/



Страницы: 1 вся ветка

Текущий архив: 2004.05.23;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.024 c
6-1080659019
Rezya
2004-03-30 19:03
2004.05.23
recv не верно возвращает колличество принятых байт.


1-1083915258
zep
2004-05-07 11:34
2004.05.23
Создание компонентов в RunTime


3-1082742571
HPR
2004-04-23 21:49
2004.05.23
Реструктуризация таблицы


3-1082626061
Eleonora
2004-04-22 13:27
2004.05.23
Interbase, Query, DBMemo


1-1083916734
En
2004-05-07 11:58
2004.05.23
Контроль другого приложения через проект дельфи