1.execute immediate
create or replace function getrealtypeforreport(p_stanid number,p_id number,p_infoname varchar2) return varchar2
is
?v_string???????????????? varchar2(200);
?v_returninfo???????????? varchar2(200);
?v_acttabname???????????? stanactive.acttabname%type;
?v_actpkcol?????????????? stanactive.actpkcol%type;
begin
???? select acttabname,actpkcol into v_acttabname,v_actpkcol from stanactive where stanid=p_stanid;
???v_string:='select realtype from vw_'||v_acttabname||' where '||v_actpkcol||' = '||p_id;
???execute immediate v_string into v_returninfo;
?return v_returninfo;
end;
/
show err;
2.?Open ttdscur for v_sql
create or replace function getfieldstring(p_expectfield varchar2,p_expecttable varchar2,p_expectcause varchar2) return varchar2
is
/*
函數功能:獲取單個屬性將其拼成一行
參數說明:p_expectfield?? 查詢字段
????????? p_expecttable?? 查詢主表
????????? p_expectcause?? 查詢條件
*/
?v_sql??? varchar2(4000):='';
?type ttds_cursor is ref cursor;
?ttdscur?????ttds_cursor;
?ttdigital????varchar2(4000);
?v_cnt?????????????????? number;
?v_return? varchar2(4000):='';
begin
?v_sql:='select '||p_expectfield||' from '||p_expecttable||' where '||p_expectcause;
?v_cnt:=0;
?Open ttdscur for v_sql;
?loop
??fetch ttdscur into ttdigital;
??exit when ttdscur%notfound;
??if v_cnt=0 then
???v_return:=ttdigital;
??else
???v_return:=v_return||','||ttdigital;
??end if;
??v_cnt:=v_cnt+1;
?end loop;
?Close ttdscur;
?return v_return;
end getfieldstring;
/
show err;
舉例:
select getfieldstring('certno','rightcert','activeid=@id and certtypeid in (3)') from dual;
?
?
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
