http://wenku.baidu.com/link?url=MnYX269RBqW9ZRh-4famwduhYq9As0-vsIyVPA7aqv64cdxxjZEOaEE1_KZ9SGjY9qCxYIb-Fuh12pN05eZDBifBvwv5tReqjNMfZyMhW3W

TYPE CURTYPE IS REF CURSOR;

TYPE C_ATTACHED_RECORD IS RECORD(

ROW_NUM          NUMBER,

PK1_VALUE        NUMBER,

USER_ENTITY_NAME VARCHAR2(1000),

TITLE            VARCHAR2(1000),

FILE_NAME        VARCHAR2(1000),

DATATYPE_NAME    VARCHAR2(1000),

FILE_DATA        BLOB,

FILE_ID          NUMBER);

----------------------------------------------------------------------------------

--功能名称:

--          GET_ATTACHED_HTML

--功能说明:

--          获取附件列表html代码

--参数说明:

--         PITEM_TYPE 工作流代码

--         P_ITEM_KEY 审批关键字

--         P_FUNCTION_NAME 附件功能名称

--         P_ENTITY_NAME 文档实体标识

--         P_TABLE_NAME 文档实体表

--         p_BLOCK_NAME 附件功能的块名

--         返回附件列表的HTML代码

--版本信息:

--          1.0     Initial Creation

----------------------------------------------------------------------------------

FUNCTION GET_ATTACHED_HTML(PITEM_TYPE      IN VARCHAR2,

PITEM_KEY       IN VARCHAR2,

P_FUNCTION_NAME IN VARCHAR2,

P_ENTITY_NAME   IN VARCHAR2,

P_TABLE_NAME    IN VARCHAR2,

p_BLOCK_NAME    IN VARCHAR2) RETURN VARCHAR2;

----------------------------------------------------------------------------------

--功能名称:

--          GET_OUTPUT_URL

--功能说明:

--          获取附件下载链接地址

--参数说明:

--         P_PK1_VALUE 附件的主关键字值

--         P_FILE_ID 附件文件ID

--         P_ENTITY_NAME 文档实体标识

--         返回指定附件文件的下载链接地址

--版本信息:

--          1.0     Initial Creation

----------------------------------------------------------------------------------

FUNCTION GET_OUTPUT_URL(P_PK1_VALUE   IN NUMBER,

P_FILE_ID     IN NUMBER,

P_ENTITY_NAME IN VARCHAR2) RETURN VARCHAR2;

/

----------------------------------------------------------------------------------

--功能名称:

--          GET_ATTACHED_HTML

--功能说明:

--          获取附件列表html代码

--参数说明:

--         PITEM_TYPE 工作流代码

--         P_ITEM_KEY 审批关键字

--         P_FUNCTION_NAME 附件功能名称

--         P_ENTITY_NAME 文档实体标识

--         P_TABLE_NAME 文档实体表

--         p_BLOCK_NAME 附件功能的块名

--         返回附件列表的HTML代码

--版本信息:

--          1.0     Initial Creation

----------------------------------------------------------------------------------

FUNCTION GET_ATTACHED_HTML(PITEM_TYPE      IN VARCHAR2,

PITEM_KEY       IN VARCHAR2,

P_FUNCTION_NAME IN VARCHAR2,

P_ENTITY_NAME   IN VARCHAR2,

P_TABLE_NAME    IN VARCHAR2,

P_BLOCK_NAME    IN VARCHAR2) RETURN VARCHAR2 IS

C_ATTACHED          CURTYPE;

V_DOCUMENT_ATTACHED VARCHAR2(32000);

VATTACHEDINFO       C_ATTACHED_RECORD;

V_COUNT             NUMBER := 1;

V_PK1_VALUE         NUMBER;

VPK1_FILED              VARCHAR2(61);

VPK2_FILED              VARCHAR2(61);

VPK3_FILED              VARCHAR2(61);

VPK4_FILED              VARCHAR2(61);

VPK5_FILED              VARCHAR2(61);

VPK1                    VARCHAR2(61);

VPK2                    VARCHAR2(61);

VPK3                    VARCHAR2(61);

VPK4                    VARCHAR2(61);

VPK5                    VARCHAR2(61);

VURL                    VARCHAR2(500);

VCONDITION_FIELD        VARCHAR2(100);

VCONDITION_OPERATOR     VARCHAR2(10);

VCONDITION_VALUE1       VARCHAR2(100);

VCONDITION_VALUE2       VARCHAR2(100);

VQUERY_PERMISSION_TYPE  VARCHAR2(10);

VINSERT_PERMISSION_TYPE VARCHAR2(10);

VUPDATE_PERMISSION_TYPE VARCHAR2(10);

VDELETE_PERMISSION_TYPE VARCHAR2(10);

V_SQL VARCHAR2(32000);

C_SQL VARCHAR2(32000);

BEGIN

BEGIN

SELECT ABE.PK1_FIELD,

ABE.PK2_FIELD,

ABE.PK3_FIELD,

ABE.PK4_FIELD,

ABE.PK5_FIELD,

ABE.CONDITION_FIELD,

ABE.CONDITION_OPERATOR,

ABE.CONDITION_VALUE1,

ABE.CONDITION_VALUE2,

ABE.QUERY_PERMISSION_TYPE,

ABE.INSERT_PERMISSION_TYPE,

ABE.UPDATE_PERMISSION_TYPE,

ABE.DELETE_PERMISSION_TYPE

INTO VPK1_FILED,

VPK2_FILED,

VPK3_FILED,

VPK4_FILED,

VPK5_FILED,

VCONDITION_FIELD,

VCONDITION_OPERATOR,

VCONDITION_VALUE1,

VCONDITION_VALUE2,

VQUERY_PERMISSION_TYPE,

VINSERT_PERMISSION_TYPE,

VUPDATE_PERMISSION_TYPE,

VDELETE_PERMISSION_TYPE

FROM FND_ATTACHMENT_BLK_ENTITIES ABE,

FND_ATTACHMENT_BLOCKS       AB,

FND_ATTACHMENT_FUNCTIONS    AF

WHERE ABE.ATTACHMENT_BLK_ID = AB.ATTACHMENT_BLK_ID

AND AB.ATTACHMENT_FUNCTION_ID = AF.ATTACHMENT_FUNCTION_ID

AND AF.FUNCTION_NAME = P_FUNCTION_NAME

AND AF.FUNCTION_TYPE = 'F'

AND ABE.DATA_OBJECT_CODE = P_ENTITY_NAME

AND AB.BLOCK_NAME = P_BLOCK_NAME

AND ROWNUM = 1;

EXCEPTION

WHEN NO_DATA_FOUND THEN

SELECT ABE.PK1_FIELD,

ABE.PK2_FIELD,

ABE.PK3_FIELD,

ABE.PK4_FIELD,

ABE.PK5_FIELD,

ABE.CONDITION_FIELD,

ABE.CONDITION_OPERATOR,

ABE.CONDITION_VALUE1,

ABE.CONDITION_VALUE2,

ABE.QUERY_PERMISSION_TYPE,

ABE.INSERT_PERMISSION_TYPE,

ABE.UPDATE_PERMISSION_TYPE,

ABE.DELETE_PERMISSION_TYPE

INTO VPK1_FILED,

VPK2_FILED,

VPK3_FILED,

VPK4_FILED,

VPK5_FILED,

VCONDITION_FIELD,

VCONDITION_OPERATOR,

VCONDITION_VALUE1,

VCONDITION_VALUE2,

VQUERY_PERMISSION_TYPE,

VINSERT_PERMISSION_TYPE,

VUPDATE_PERMISSION_TYPE,

VDELETE_PERMISSION_TYPE

FROM FND_ATTACHMENT_BLK_ENTITIES ABE,

FND_ATTACHMENT_BLOCKS       AB,

FND_ATTACHMENT_FUNCTIONS    AF

WHERE ABE.ATTACHMENT_BLK_ID = AB.ATTACHMENT_BLK_ID

AND AB.ATTACHMENT_FUNCTION_ID = AF.ATTACHMENT_FUNCTION_ID

AND AF.FUNCTION_NAME = P_FUNCTION_NAME

AND AF.FUNCTION_TYPE = 'O'

AND ABE.DATA_OBJECT_CODE = P_ENTITY_NAME

AND AB.BLOCK_NAME = P_BLOCK_NAME

AND ROWNUM = 1;

END;

V_SQL := 'SELECT ' || SUBSTR(VPK1_FILED,

INSTR(VPK1_FILED, '.', 1) + 1,

LENGTH(VPK1_FILED)) || ' FROM ' ||

P_TABLE_NAME || ' WHERE ITEM_KEY = ''' || PITEM_KEY || '''' ||

' AND ROWNUM = 1';

EXECUTE IMMEDIATE V_SQL

INTO V_PK1_VALUE;

V_DOCUMENT_ATTACHED := '<table  width=100% border="0" cellspacing="0" cellpadding="0" >

<tr><td><table cellpadding="0" cellspacing="0" border="0" width="100%" class="x74" style="background-image:url(/OA_HTML/cabo/images/swan/headingBarBg.gif);">

<tr>

<td width="100%"><h2 class="x75">附件列表</h2></td></tr></table></td></tr>

<tr><td><table width="100%" class="x1h" cellpadding="1" cellspacing="0" summary="Action History" border="1" >

<tr>

<th class="x1r x4j"  scope="col" width="2%" align="LEFT" valign="baseline" ><span class="x24">序号</span></th>

<th class="x1r x4j"  scope="col" width="5%" align="LEFT" valign="baseline" ><span class="x24">实体名</span></th>

<th class="x1r x4j"  scope="col" width="10%" align="LEFT" valign="baseline" ><span class="x24">标题</span></th>

<th class="x1r x4j"  scope="col" width="15%" align="LEFT" valign="baseline" ><span class="x24">文件名</span></th>

</tr>';

C_SQL := 'SELECT ROWNUM ROW_NUM,

PK1_VALUE,

USER_ENTITY_NAME,

TITLE,

FILE_NAME,

DATATYPE_NAME,

FILE_DATA,

FILE_ID

FROM (SELECT FAD.PK1_VALUE,

FAD.USER_ENTITY_NAME,

FAD.TITLE,

FAD.FILE_NAME,

FAD.DATATYPE_NAME,

FL.FILE_DATA,

FL.FILE_ID

FROM FND_ATTACHED_DOCS_FORM_VL FAD, FND_LOBS FL

WHERE FAD.MEDIA_ID = FL.FILE_ID

AND FAD.FUNCTION_NAME = ''' ||

P_FUNCTION_NAME ||''''||

' AND FAD.PK1_VALUE IN ' ||

'(SELECT T.' ||

SUBSTR(VPK1_FILED,

INSTR(VPK1_FILED, '.', 1) + 1,

LENGTH(VPK1_FILED)) ||

' FROM ' || P_TABLE_NAME ||

' T WHERE T.ITEM_KEY = ''' ||

PITEM_KEY || '''' || ')

AND FAD.ENTITY_NAME = '''||P_ENTITY_NAME||''''

||' ORDER BY FAD.USER_ENTITY_NAME, FAD.SEQ_NUM)';

OPEN C_ATTACHED FOR C_SQL;

FETCH C_ATTACHED

INTO VATTACHEDINFO;

WHILE C_ATTACHED%FOUND LOOP

V_DOCUMENT_ATTACHED := V_DOCUMENT_ATTACHED ||

'<tr>

<td align="LEFT" valign="baseline"  class="x1l x4x">' ||

V_COUNT ||

'</td>

<td align="LEFT" valign="baseline"  class="x1l x4x">' ||

VATTACHEDINFO.USER_ENTITY_NAME ||

'</td>

<td align="LEFT" valign="baseline"  class="x1l x4x">' ||

VATTACHEDINFO.TITLE || '</td>

<td align="LEFT" valign="baseline"  class="x1l x4x">

<a href="' ||

GET_OUTPUT_URL(V_PK1_VALUE,

VATTACHEDINFO.FILE_ID,

P_ENTITY_NAME) || '">' ||

VATTACHEDINFO.FILE_NAME || '</a></td>

</tr>';

V_COUNT := V_COUNT + 1;

FETCH C_ATTACHED

INTO VATTACHEDINFO;

END LOOP;

V_DOCUMENT_ATTACHED := V_DOCUMENT_ATTACHED ||

'</table></td></tr></table>';

RETURN V_DOCUMENT_ATTACHED;

EXCEPTION

WHEN OTHERS THEN

RETURN NULL;

END GET_ATTACHED_HTML;

----------------------------------------------------------------------------------

--功能名称:

--          GET_OUTPUT_URL

--功能说明:

--          获取附件下载链接地址

--参数说明:

--         P_PK1_VALUE 附件的主关键字值

--         P_FILE_ID 附件文件ID

--         P_ENTITY_NAME 文档实体标识

--         返回指定附件文件的下载链接地址

--版本信息:

--          1.0     Initial Creation

----------------------------------------------------------------------------------

/*FUNCTION GET_OUTPUT_URL(P_PK1_VALUE IN NUMBER, P_FILE_ID IN NUMBER,P_ENTITY_NAME IN VARCHAR2)

    RETURN VARCHAR2 IS

    P_ACCESS_ID  NUMBER;

    V_OUTPUT_URL VARCHAR2(10000);

  BEGIN

    V_OUTPUT_URL := '';

 

    SELECT ACCESS_ID

      INTO P_ACCESS_ID

      FROM FND_LOB_ACCESS

     WHERE FILE_ID = P_FILE_ID;

 

    V_OUTPUT_URL := RPT_REG_PKG.G_XML_PATH\*是一个配置文件值可以自己定义修改,值如:http://db1.dtpower.zszy.com:8001\*\ ||

                    'OA_HTML/fndgfm.jsp?mode=download_blob&fid=' ||

                    P_FILE_ID || '&accessid=' || P_ACCESS_ID;

    RETURN V_OUTPUT_URL;

  EXCEPTION

    WHEN NO_DATA_FOUND THEN

      INSERT INTO FND_LOB_ACCESS

        (ACCESS_ID, FILE_ID, TIMESTAMP)

        SELECT TO_NUMBER(TO_CHAR(FND_LOBS_S.NEXTVAL) ||

                         TO_CHAR(SYSDATE, 'SSSSS')),

               D.MEDIA_ID,

               SYSDATE + 1

          FROM FND_ATTACHED_DOCUMENTS B,

               FND_DOCUMENTS_TL       C,

               FND_DOCUMENTS          D

         WHERE B.DOCUMENT_ID = C.DOCUMENT_ID

           AND B.DOCUMENT_ID = D.DOCUMENT_ID

           AND B.PK1_VALUE = P_PK1_VALUE

           AND D.MEDIA_ID = P_FILE_ID

           AND B.ENTITY_NAME = P_ENTITY_NAME

           AND C.LANGUAGE = 'ZHS';

      COMMIT;

      SELECT ACCESS_ID

        INTO P_ACCESS_ID

        FROM FND_LOB_ACCESS

       WHERE FILE_ID = P_FILE_ID;

      V_OUTPUT_URL := RPT_REG_PKG.G_XML_PATH ||

                      'OA_HTML/fndgfm.jsp?mode=download_blob&fid=' ||

                      P_FILE_ID || '&accessid=' || P_ACCESS_ID;

      RETURN V_OUTPUT_URL;

    WHEN OTHERS THEN

      P_ACCESS_ID  := 0;

      V_OUTPUT_URL := '';

      XZTZ_LOG_PKG.INSERT_LOG('附件列表文件下载链接生成异常',

                             SQLERRM,

                             'XZ_PO_PUB_PKG.GET_OUTPUT_URL',

                             30);

      RETURN V_OUTPUT_URL;

  END GET_OUTPUT_URL;*/

FUNCTION GET_OUTPUT_URL(P_PK1_VALUE   IN NUMBER,

P_FILE_ID     IN NUMBER,

P_ENTITY_NAME IN VARCHAR2) RETURN VARCHAR2 IS

P_ACCESS_ID  NUMBER;

V_OUTPUT_URL VARCHAR2(10000);

BEGIN

/* V_SQL_STR := 'SELECT d.file_name,d.media_id ,a.access_id,

       fnd_gfm.construct_download_url(fnd_web_config.gfm_agent,d.media_id) URL ' ||

    ' from fnd_attached_documents b,fnd_documents_tl c,fnd_lob_access a,fnd_documents d' ||

    ' where b.document_id=c.document_id and  b.document_id=d.document_id and b.pk1_value=''' ||

    V_PK1_VALUE || '''' ||

    ' and a.file_id=d.media_id and b.entity_name IN (''XZ_PO_EXPENDED'',''XZ_PO_EXPENDED'')

        and C.LANGUAGE=''ZHS'' '; */

V_OUTPUT_URL := FND_GFM.CONSTRUCT_DOWNLOAD_URL(FND_WEB_CONFIG.GFM_AGENT, /*应用产品 Web 代理配置文件值:http://db1.dtpower.zszy.com:8001/pls/TEST*/

P_FILE_ID);

RETURN V_OUTPUT_URL;

EXCEPTION

WHEN OTHERS THEN

P_ACCESS_ID  := 0;

V_OUTPUT_URL := '';

XZTZ_LOG_PKG.INSERT_LOG('附件列表文件下载链接生成异常',

SQLERRM,

'XZ_PO_PUB_PKG.GET_OUTPUT_URL',

30);

RETURN V_OUTPUT_URL;

END GET_OUTPUT_URL;

最终效果:

最新文章

  1. apache2.4配置Django1.7运行环境
  2. 【SPI】Polling Interrupt DMA
  3. 【C#】【Thread】Semaphore/SemaphoreSlim信号量
  4. MVC5+EF6 简易版CMS(非接口) 第三章:数据存储和业务处理
  5. 利用URLScan工具过滤URL中的特殊字符(仅针对IIS6)-- 解决IIS短文件名漏洞
  6. 【HDOJ】4587 TWO NODES
  7. (转)浅谈dedecms模板引擎工作原理及自定义标签
  8. TensorFlow深度学习笔记 循环神经网络实践
  9. sql语句优化之not in
  10. php生成PDF文件(FPDF)
  11. Leetcode-1.两数之和
  12. SpringMVC流程架构基础理论
  13. 整数m去掉n位后剩下最大(小)值
  14. oracle 创建create user 及授权grant 查看登陆的用户
  15. 03 Files
  16. c++ c++ 与 Java
  17. python安装包的时候报错
  18. python多线程(一)
  19. sublime text 3 文件列表忽略特定格式的文件
  20. [ZPG TEST 116] 最小边权和【生成树相关】

热门文章

  1. JDK、JRE和JAR区别(转载)
  2. fiddler 发送get请求
  3. spring security 非页面登录
  4. Windows平台下Flutter安装,配置,初运行。
  5. eclipse搭建struts2环境及所遇到的问题
  6. 整合Struts2框架和Spring框架
  7. Algorithmic Trading[z]
  8. vmware fusion 10序列号
  9. 11月11日光棍节考试总结hhh
  10. java.text.SimpleDateFormat的使用