详解EBS接口开发之更新供应商付款方法
更新供应商地点层的付款方法API
DECLARE
--API 参数
l_external_payee_rec_type iby_disbursement_setup_pub.external_payee_rec_type;
l_ext_payee_id_rec_type iby_disbursement_setup_pub.ext_payee_id_rec_type;
l_ext_payee_tab iby_disbursement_setup_pub.external_payee_tab_type;
l_ext_payee_id_tab iby_disbursement_setup_pub.ext_payee_id_tab_type;
l_ext_payee_status_tab iby_disbursement_setup_pub.ext_payee_update_tab_type; --变量
l_api_version CONSTANT NUMBER := 1;
l_msg_data VARCHAR2(2000);
l_msg VARCHAR2(4000);
l_msg_count NUMBER;
l_return_status VARCHAR2(1);
l_method_code VARCHAR2(50); l_vendor_id NUMBER;
l_party_id NUMBER;
l_party_site_id NUMBER;
l_location_id NUMBER;
l_vendor_site_id NUMBER;
l_object_version_number NUMBER;
l_loc_version_number NUMBER;
g_def_exclusive_pay_flag VARCHAR2(1) := 'Y';
--l_party_id NUMBER;
--游标
CURSOR cur_cux_vendor IS
SELECT l.vendor_site_code, l.attribute2, l.line_id
FROM cux_oms_vendor_site l
WHERE l.attribute2 IS NULL
FOR UPDATE NOWAIT; CURSOR cur_ap_vendor(p_vendor_site_code IN VARCHAR2) IS
SELECT l.vendor_id, l.vendor_site_id, l.org_id, l.party_site_id
FROM ap_supplier_sites_all l
WHERE l.vendor_site_code = p_vendor_site_code; CURSOR c_payment_method(p_vendor_id IN VARCHAR2,
p_vendor_site_id IN NUMBER) IS
SELECT a.ext_payee_id,
a.payment_function,
a.supplier_site_id,
a.party_site_id,
a.org_id,
a.org_type,
a.object_version_number,
pv.party_id,
s.attribute2
FROM ap_supplier_sites_all s,
iby_external_payees_all a,
po_vendors pv
WHERE (s.inactive_date IS NULL OR
trunc(s.inactive_date) >= trunc(SYSDATE))
AND a.supplier_site_id(+) = s.vendor_site_id
AND s.vendor_id = pv.vendor_id
AND a.payee_party_id = pv.party_id
AND s.org_id = a.org_id(+)
AND s.party_site_id = a.party_site_id(+)
AND s.vendor_site_id = p_vendor_site_id
AND pv.vendor_id = p_vendor_id; BEGIN
fnd_global.apps_initialize(user_id => 1110,
resp_id => 20639,
resp_appl_id => 200);
FOR rec_cux_vendor IN cur_cux_vendor LOOP
FOR rec_ap_vendor IN cur_ap_vendor(p_vendor_site_code => rec_cux_vendor.vendor_site_code) LOOP
--初始化参数
mo_global.set_policy_context(p_access_mode => 'S',
p_org_id => rec_ap_vendor.org_id);
FOR r_payment_method IN c_payment_method(p_vendor_id => rec_ap_vendor.vendor_id,
p_vendor_site_id => rec_ap_vendor.vendor_site_id) LOOP
l_ext_payee_id_rec_type := NULL;
l_ext_payee_id_tab.delete;
l_external_payee_rec_type := NULL;
l_ext_payee_tab.delete; SELECT l.party_id
INTO l_party_id
FROM ap_suppliers l
WHERE l.vendor_id = rec_ap_vendor.vendor_id; --update site level ext pay infor
l_ext_payee_id_rec_type := NULL;
l_ext_payee_id_tab.delete;
l_external_payee_rec_type := NULL;
l_ext_payee_tab.delete;
--init param p_ext_payee_id_tab
l_ext_payee_id_rec_type.ext_payee_id := r_payment_method.ext_payee_id;
l_ext_payee_id_tab(1) := l_ext_payee_id_rec_type;
--init param p_ext_payee_tab
l_external_payee_rec_type.payee_party_site_id := r_payment_method.party_site_id;
l_external_payee_rec_type.payee_party_id := r_payment_method.party_id; --p_party_id;
l_external_payee_rec_type.payment_function := r_payment_method.payment_function;
l_external_payee_rec_type.payer_org_id := r_payment_method.org_id;
l_external_payee_rec_type.supplier_site_id := r_payment_method.supplier_site_id;
l_external_payee_rec_type.payer_org_type := r_payment_method.org_type;
l_external_payee_rec_type.exclusive_pay_flag := g_def_exclusive_pay_flag; /*SELECT pmv.payment_method_code
INTO l_method_code
FROM iby_payment_methods_vl pmv
WHERE pmv.payment_method_name = '银行电汇'
AND SYSDATE < nvl(pmv.inactive_date, SYSDATE + 1);*/ l_external_payee_rec_type.default_pmt_method := 'BZ_CHECK';
l_ext_payee_tab(1) := l_external_payee_rec_type; iby_disbursement_setup_pub.update_external_payee(p_api_version => l_api_version,
p_init_msg_list => 'T',
p_ext_payee_tab => l_ext_payee_tab,
p_ext_payee_id_tab => l_ext_payee_id_tab,
x_return_status => l_return_status,
x_msg_count => l_msg_count,
x_msg_data => l_msg_data,
x_ext_payee_status_tab => l_ext_payee_status_tab);
IF l_return_status != fnd_api.g_ret_sts_success THEN IF l_msg_data IS NULL THEN
l_msg_data := fnd_msg_pub.get(p_msg_index => fnd_msg_pub.g_last,
p_encoded => 'F'); --get last message
dbms_output.put_line('l_msg_data:' || SQLERRM);
END IF; --IF l_msg_data IS NULL THEN END IF; --IF l_return_status != fnd_api.g_ret_sts_success THEN
END LOOP; --FOR r_payment_method IN c_payment_method(p_vendor_id =>rec_ap_vendor.vendor_id, END LOOP; --for rec_ap_vendor in cur_ap_vendor(p_vendor_site_code =>rec_cux_vendor.vendor_site_code) loop
UPDATE cux_oms_vendor_site L
SET L.ATTRIBUTE2 = 'BZ_CHECK'
WHERE L.LINE_ID = rec_cux_vendor.LINE_ID;
END LOOP; --for rec_cux_vendor in cur_cux_vendor loop
END;
详解EBS接口开发之更新供应商付款方法的更多相关文章
- 供应商API补充(详解EBS接口开发之供应商导入)(转)
原文地址 供应商导入的API补充(详解EBS接口开发之供应商导入) --供应商 --创建 AP_VENDOR_PUB_PKG.Create_Vendor ( p_api_version IN NUM ...
- 详解EBS接口开发之库存事务处理批次更新
库存事务处理批次有时候出现导入错误需要更新可使用次程序更新,批次导入可参考博客 详解EBS接口开发之库存事务处理-物料批次导入 http://blog.csdn.net/cai_xingyun/art ...
- 详解EBS接口开发之库存事务处理采购接收--补充
除了可以用 详解EBS接口开发之库存事务处理采购接收的方法还可以用一下方法,不同之处在于带有批次和序列控制的时候实现方式不同 The script will load records into ...
- 详解EBS接口开发之采购申请导入
更多内容可以参考我的博客 详解EBS接口开发之采购订单导入 http://blog.csdn.net/cai_xingyun/article/details/17114697 /*+++++++ ...
- 详解EBS接口开发之供应商导入
(一)供应商常用标准表简介 1.1 常用标准表 如下表中列出了与供应商相关的表和说明: 表名 说明 其他信息 ap_suppliers 供应商头表 供应商的头信息如:供应商名.供应商编码.税号等 ...
- 详解EBS接口开发之应收款处理
参考实例参考:杜春阳 R12应收模块收款API研究 (一)应收款常用标准表简介 1.1 常用标准表 如下表中列出了与应收款处理相关的表和说明: 表名 说明 其他信息 AR_BATCHES_ALL ...
- 详解EBS接口开发之供应商导入(补充)--供应商银行账户更新
CREATE OR REPLACE PACKAGE BODY update_vendor_account IS PROCEDURE main(errbuf OUT VARCHAR2, retcode ...
- 供应商导入的API补充(详解EBS接口开发之供应商导入)
--供应商 --创建 AP_VENDOR_PUB_PKG.Create_Vendor ( p_api_version IN NUMBER, p_init_msg_list IN VARCHAR2 := ...
- 详解EBS接口开发之供应商导入(补充)--错误信息处理
check reject details on records of AP_SUPPLIER_INT SELECT s.parent_table,s.reject_lookup_code,S.LAST ...
随机推荐
- eclipse中安装freemarker插件及ftl使用freemarker编辑器
http://www.07net01.com/2015/08/895212.html eclipse中安装freemarker插件及ftl使用freemarker编辑器 在线安装的方法是:Help – ...
- Java Web -【分页功能】详解
分页简介 分页功能在网页中是非常常见的一个功能,其作用也就是将数据分割成多个页面来进行显示. 使用场景: 当取到的数据量达到一定的时候,就需要使用分页来进行数据分割. 当我们不使用分页功能的时候,会面 ...
- Java编写高质量代码改善程序的151个建议
第一章 Java开发中通用的方法和准则 建议1:不要在常量和变量中出现易混淆的字母: (i.l.1:o.0等). 建议2:莫让常量蜕变成变量: (代码运行工程中不要改变常量值). 建议3:三元操作符 ...
- 解决 Popup 位置不随窗口移动更新的问题
Popup弹出后,因业务需求设置了StaysOpen=true后,移动窗口位置或者改变窗口大小,Popup的位置不会更新. 如何更新位置? 获取当前Popup的Target绑定UserControl所 ...
- WIN2008虚拟机安装ORACLE11g记录
---恢复内容开始--- 1.ORACLE11g的安装包下载与解压 官网下载地址:(http://www.oracle.com/technetwork/database/enterprise-edit ...
- vim 基本命令入门
简介 vim是Linux 系统下类似于Windows的记事本的编辑器. vim 中经常使用的三种模式 一般模式:浏览文件内容. 插入模式:编辑文件内容. 底行模式:进行保存编辑内容,退出等操作. 基本 ...
- Go 语言指针
Go 语言中指针是很容易学习的,Go 语言中使用指针可以更简单的执行一些任务. 接下来让我们来一步步学习 Go 语言指针. 我们都知道,变量是一种使用方便的占位符,用于引用计算机内存地址. Go 语言 ...
- Swift基础之两种选择星星的评价样式并获取星星的索引值
想练练手,所以封装了一个两种选择星星的评价样式的Demo,并且可以获取到点击的星星的索引值,方便记录值,上传数据时使用 首先创建View类,设计初始化方法,并且用到了枚举类型和代理方法 方式一:默认的 ...
- springMVC源码分析--SimpleServletHandlerAdapter(二)
上一篇博客springMVC源码分析--HandlerAdapter(一)中我们主要介绍了一下HandlerAdapter接口相关的内容,实现类及其在DispatcherServlet中执行的顺序,接 ...
- Spring基础配置
从毕业到现在我一直从事Android开发,但是对JavaEE一直念念不忘,毕业校招的时候,一个礼拜拿了三个offer,岗位分别是Android.JavaEE和JavaSE,后来觉得Android比较简 ...