Oracle Report中加入下载超链接操作方法

1、在报表页面布局相应的位置加入文本框,一般为Download
右键用PL/SQL编辑器编写成超链接,加入以下内容:
<div class="codetitle"><a style="CURSOR: pointer" data="66669" class="copybut" id="copybut66669" onclick="doCopy('code66669')"> 代码如下:<div class="codebody" id="code66669">
function B_13FormatTrigger return boolean is
begin
IF upper(:P_ACTION) != 'DOWNLOAD' THEN
return (FALSE);
ELSE
srw.set_hyperlink(EXP_FILE.linkto);
return (TRUE);
END IF;
end;

2、建立程序单元EXP_FILE和EXP_FILE,加入link_to函数,内容如下:
<div class="codetitle"><a style="CURSOR: pointer" data="58383" class="copybut" id="copybut58383" onclick="doCopy('code58383')"> 代码如下:<div class="codebody" id="code58383">
FUNCTION linkto RETURN VARCHAR2
IS
BEGIN
RETURN (:P_URL||filename);
END linkto;

3、编写触发器BEFORE_REPORT,把要下载内容追加到下载页面中,内容如下:
<div class="codetitle"><a style="CURSOR: pointer" data="36357" class="copybut" id="copybut36357" onclick="doCopy('code36357')"> 代码如下:<div class="codebody" id="code36357">
function BeforeReport return boolean is
begin
If upper(:P_ACTION) = 'DOWNLOAD' then
:P_SESSION := USERENV('SESSIONID');
:P_TEST := EXP_FILE.make('Vendor_Item_ReferenceEnquiry'||to_char(sysdate,'yyyymmddhh24miss'),:P_USERID,'csv',false);
EXP_FILE.append('|'||'|'||'|'||'|'||'Vendor Item Reference Enquiry'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|');
EXP_FILE.append('|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|');
EXP_FILE.append('Selection criteria'||'|'||'CCN:'||'|'||:P_CCN||'|'||'|'||'Mas Loc:'||'|'||:P_MASLOC||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|');
EXP_FILE.append('|'||'Division:'||'|'||:P_FR_DIV||'|'||'|'||'To:'||'|'||:P_TO_DIV||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|');
EXP_FILE.append('|'||'|'||'Vendor:'||'|'||:P_FR_VENDOR||'|'||'|'||'To:'||'|'||:P_TO_VENDOR||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|');
EXP_FILE.append('|'||'|'||'Item:'||'|'||:P_FR_ITEM||'|'||'|'||'To:'||'|'||:P_TO_ITEM||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|'||'|');
EXP_FILE.append('Dept*'|| '|' ||'Vendor'||'|'||'Pur Loc '||'|'||'Item'||'|'||'Make'||'|'||'Description'||'|'||'Env. Std.'||'|'||'Env. Status ');
return(true);
else
return(true);
end if;
end;

dawei

【声明】:淮南站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。