本节实现将并发请求输出PDF文件添加到工作流附件

省去了工作流中其他部分,只对附件部分介绍

1.       建立一个类型为Document的Attribute

2.       通知界面上创建附件链接

找到Notification下对应的Message;

将第一步中创建的Attribute复制到这个Message下面:

修改复制后的Attribute的属性

至此,Notification页面便存在一个附件链接。

3.       工作流中为附件Attribute赋值

在工作流执行过程中,代码实现对attribute进行赋值:

使用API:

wf_engine.setitemattrdocument

(itemtype        => l_itemtype,

itemkey         => l_itemkey,

aname           => 'TCL_PDF_ATTACH',

documentid      =>    'PLSQLBLOB:KS_OM_TEMP_CREDIT_LIMIT_PKG.READ_REPORT/KSOMTCLA:' || l_itemkey || ':'  || l_tcl_pdf

);

此处API中documentid  参数的固定格式为以下三种:

PLSQL:<procedure>/<document_identifier>;

PLSQLCLOB:<procedure>/<document_identifier>;

PLSQLBLOB:<procedure>/<document_identifier>;

4.       实现读取PDF文件的Procedure

该procedure的传入参数存在固定的格式:

/*

procedure <procedure name>

(document_id in varchar2,

display_type in varchar2,

document in out nocopy varchar2,

document_type in out nocopy varchar2);

procedure <procedure name>

(document_id in varchar2,

display_type in varchar2,

document in out nocopy clob,

document_type in out nocopy varchar2);

procedure <procedure name>

(document_id in varchar2,

display_type in varchar2,

document in out nocopy blob,

document_type in out nocopy varchar2);

*/

读取文件的代码:

PROCEDURE read_report (

document_id     IN       VARCHAR2,

display_type    IN       VARCHAR2,

document        IN OUT   BLOB,

document_type   IN OUT   VARCHAR2

)

IS

lfile_name   VARCHAR2 (240); --读取的目标文件名

lfile        BFILE;

BEGIN

/*从传入的参数中提取目标文件的名称*/

SELECT SUBSTR (document_id, INSTR (document_id, ':', -1) + 1)

INTO lfile_name

FROM DUAL;

/*BFILENAME是读取目录KS_FND_CONC_OUT下的文件lfile_name*/

lfile := BFILENAME ('KS_FND_CONC_OUT', lfile_name);

DBMS_LOB.OPEN (lfile, DBMS_LOB.lob_readonly);

DBMS_LOB.OPEN (document, DBMS_LOB.lob_readwrite);

document_type := 'application/pdf';

/*将lfile写入document*/

DBMS_LOB.loadfromfile (dest_lob => document,

    src_lob => lfile,

    amount => DBMS_LOB.getlength (lfile)

    );

DBMS_LOB.CLOSE (lfile);

DBMS_LOB.CLOSE (document);

END read_report;

添加并发请求PDF到工作流附件的更多相关文章

  1. Dynamics 365触发Microsoft Flow自动生成PDF并作为附件送邮件

    我是微软Dynamics 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面 ...

  2. Jexus 高并发请求的优化技巧 笔记

    Jexus web server 5.1 每个工作进程的最大并发数固定为1万,最多可以同时开启4个工作进程,因此,每台Jexus V5.1服务器最多可以到支持4万个并发连接.但是,按照linux系统的 ...

  3. 开源个.NetCore写的 - 并发请求工具PressureTool

    本篇和大家分享的是一个 并发请求工具,并发往往代表的就是压力,对于一些订单量比较多的公司这种情况很普遍,也因此出现了很多应对并发的解决方案如:分布式,队列,数据库锁等: 对于没有遇到过或者不可能线上来 ...

  4. Asp.net并发请求导致的数据重复插入问题

    前段时间工作中,有客户反应了系统中某类待办重复出现两次的情况.我核实了数据之后,分析认为是并发请求下导致的数据不一致性问题,并做了重现.其实这并不是一个需要频繁调用的功能,但是客户连续点击了两次,导致 ...

  5. 达达O2O后台架构演进实践:从0到4000高并发请求背后的努力

    1.引言   达达创立于2014年5月,业务覆盖全国37个城市,拥有130万注册众包配送员,日均配送百万单,是全国领先的最后三公里物流配送平台. 达达的业务模式与滴滴以及Uber很相似,以众包的方式利 ...

  6. 使用HttpClient实现并发请求

    在.Net 4.0之前,一直是依靠HttpWebRequest实现Http操作的.它默认有一个非常保守的同一站点下最大2并发数限制,导致默认情况下HttpWebRequest往往得不到理想的速度,必须 ...

  7. 初学Jmeter添加Http请求,执行接口测试

    最近测试并发,刚开始使用的是录制方法,后面发现录制后无任何界面,加参数也不知从何着手,于是查了很多文章,终于慢慢的着手从http请求来测试并发了. 当然这是个遗留问题,先放在这里后面清楚了再回来补充: ...

  8. PHP实现并发请求

    后端服务开发中经常会有并发请求的需求,比如你需要获取10家供应商的带宽数据(每个都提供不同的url),然后返回一个整合后的数据,你会怎么做呢? 在PHP中,最直观的做法foreach遍历urls,并保 ...

  9. 支持10W高并发请求的IIS Web服务器常用设置

    支持高并发的IIS Web服务器常用设置   适用的IIS版本:IIS 7.0, IIS 7.5, IIS 8.0 适用的Windows版本:Windows Server 2008, Windows ...

随机推荐

  1. P1082 同余方程

    题意:给定a,b,求$ax \equiv 1 \pmod b$的最小正整数解x,保证有解 exgcd:求$ax+by=gcd(a,b)$的 一组解x,y 首先根据正常的gcd可得出   $gcd(a, ...

  2. Leetcode 566. Reshape the Matrix 矩阵变形(数组,模拟,矩阵操作)

    Leetcode 566. Reshape the Matrix 矩阵变形(数组,模拟,矩阵操作) 题目描述 在MATLAB中,reshape是一个非常有用的函数,它可以将矩阵变为另一种形状且保持数据 ...

  3. Jenkins 相关

    手动下载Jenkins plugin 的地址, 下载后的是zip 文件,然后再手动修改为.hpi 文件,然后再手动上传 https://plugins.jenkins.io/

  4. (转)TestNG框架提供两种传入参数的方法:

    1.从testng.xml传入参数. 如果参数是一些简单的值,可以直接在testng.xml中定义.这也是最常用的一种. 可以在测试用例中给参数一个默认值.这样,即使在xml文件中没有这个变量,你的测 ...

  5. KindEditor的参考文献

    转自:http://www.cnblogs.com/wupeiqi/articles/6307554.html

  6. node.js 设置 淘宝 镜像

    npm config set registry "https://registry.npm.taobao.org" npm info underscore (如果上面配置正确这个命 ...

  7. 1001 害死人不偿命的(3n+1)猜想 (15)(15 分)

    卡拉兹(Callatz)猜想: 对任何一个自然数n,如果它是偶数,那么把它砍掉一半:如果它是奇数,那么把(3n+1)砍掉一半.这样一直反复砍下去,最后一定在某一步得到n=1.卡拉兹在1950年的世界数 ...

  8. iOS自动化测试的那些干货

    前言 如果有测试大佬发现内容不对,欢迎指正,我会及时修改. 大多数的iOS App(没有持续集成)迭代流程是这样的 也就是说,测试是发布之前的最后一道关卡.如果bug不能在测试中发现,那么bug就会抵 ...

  9. js学习笔记 -- 随记

    js不区分整数和浮点数,统一用Number表示, js'=='比较会自动转换类型,会产生奇怪结果,'==='不会转换比较类型,如果不一致返回false,因此js判断始终用'===' `` 保留换行,也 ...

  10. jdk源码分析——java.lang.Boolean

      1.Boolean类里面的2个静态变量. Boolean类,直接声明了2个静态变量,TRUE 和 FALSE,指向2个对象.     public static final Boolean TRU ...