DECLARE
l_num_user_id NUMBER;
l_num_appl_id NUMBER;
l_num_resp_id NUMBER;
cust_account_rec_type hz_cust_account_v2pub.cust_account_rec_type;
l_num_obj_ver_num NUMBER;
l_chr_return_status VARCHAR2(2000);
l_num_msg_count NUMBER;
l_chr_msg_data VARCHAR2(500);
l_num_profile_id NUMBER;
l_organization_rec hz_party_v2pub.organization_rec_type;
l_customer_profile_rec hz_customer_profile_v2pub.customer_profile_rec_type;
l_num_cust_id NUMBER;
l_chr_acct_num VARCHAR2(500);
l_num_party_id NUMBER;
l_chr_party_number VARCHAR2(500);
l_cust_acct_site_use_rec hz_cust_account_site_v2pub.cust_site_use_rec_type;
l_cust_acct_site_rec hz_cust_account_site_v2pub.cust_acct_site_rec_type;
l_chr_sit_return_status VARCHAR2(500);
l_num_sit_msg_count NUMBER;
l_chr_sit_msg_data VARCHAR2(500);
l_chr_situ_return_status VARCHAR2(500);
l_num_situ_msg_count NUMBER;
l_chr_situ_msg_data VARCHAR2(500);
l_num_site_use_id NUMBER;
CURSOR update_base_tables_cur IS
SELECT DISTINCT a.party_number,
ps.party_site_number,
a.party_id,
'CUST-' || a.party_id || '-' || ass.org_id AS customer_ref,
'ADD-' || ps.party_site_id || '-' || ass.org_id AS address_ref,
ps.party_site_id,
ass.address_line1,
ass.city,
ass.state,
ass.zip,
ass.country,
'N' primary_site_use_flag,
a.orig_system_reference AS party_ref,
a.party_name AS customer_name,
ass.org_id
FROM apps.ap_suppliers ap,
apps.ap_supplier_sites_all ass,
apps.hz_parties a,
apps.hz_party_sites ps
WHERE ap.vendor_id = ass.vendor_id
AND a.party_id = ap.party_id
AND ps.party_id = ap.party_id
AND ass.party_site_id = ps.party_site_id
AND a.party_name = ap.vendor_name
AND a.party_id = 12465 -- modify this part/query
--and ass.org_id = 204
AND NOT EXISTS
(SELECT 1 FROM hz_cust_accounts a WHERE a.party_id = a.party_id);
BEGIN
fnd_global.apps_initialize(&user_id, &responsibility_id, 222); -- input from 1st sql
dbms_output.put_line('***************************');
FOR update_base_tables_rec IN update_base_tables_cur LOOP
NULL;
cust_account_rec_type.cust_account_id := fnd_api.g_miss_num;
cust_account_rec_type.account_name := update_base_tables_rec.customer_name;
l_organization_rec.party_rec.party_id := update_base_tables_rec.party_id;
l_organization_rec.party_rec.party_number := update_base_tables_rec.party_number;
l_organization_rec.organization_name := update_base_tables_rec.customer_name;
cust_account_rec_type.orig_system_reference := update_base_tables_rec.customer_ref;
l_customer_profile_rec.party_id := update_base_tables_rec.party_id;
l_customer_profile_rec.profile_class_id := 0; -- use DEFAULT profile with id=0
l_customer_profile_rec.created_by_module := 'HZ_CPUI';
cust_account_rec_type.created_by_module := 'HZ_CPUI';
hz_cust_account_v2pub.create_cust_account(p_init_msg_list => fnd_api.g_false,
p_cust_account_rec => cust_account_rec_type,
p_organization_rec => l_organization_rec,
p_customer_profile_rec => l_customer_profile_rec,
p_create_profile_amt => fnd_api.g_true,
x_cust_account_id => l_num_cust_id,
x_account_number => l_chr_acct_num,
x_party_id => l_num_party_id,
x_party_number => l_chr_party_number,
x_profile_id => l_num_profile_id,
x_return_status => l_chr_return_status,
x_msg_count => l_num_msg_count,
x_msg_data => l_chr_msg_data);
dbms_output.put_line('x_return_status: ' || l_chr_return_status);
dbms_output.put_line('x_cust_account_id: ' || l_num_cust_id);
dbms_output.put_line('x_account_number: ' || l_chr_acct_num);
dbms_output.put_line('x_party_id: ' || l_num_party_id);
IF l_chr_return_status != 'S' THEN
--Display all the error messages
FOR j IN 1 .. fnd_msg_pub.count_msg LOOP
dbms_output.put_line(j);
l_chr_msg_data := fnd_msg_pub.get(p_msg_index => j,
p_encoded => 'F');
dbms_output.put_line('Message(' || j || '):= ' ||
l_chr_msg_data);
END LOOP;
END IF;
BEGIN
SELECT cust_account_id
INTO l_cust_acct_site_rec.cust_account_id
FROM hz_cust_accounts
WHERE orig_system_reference = update_base_tables_rec.customer_ref;
EXCEPTION
WHEN OTHERS THEN
l_cust_acct_site_rec.cust_account_id := fnd_api.g_miss_num;
END;
l_cust_acct_site_rec.party_site_id := update_base_tables_rec.party_site_id;
l_cust_acct_site_rec.created_by_module := 'HZ_CPUI';
l_cust_acct_site_rec.orig_system_reference := update_base_tables_rec.address_ref;
l_cust_acct_site_rec.status := 'A';
l_cust_acct_site_rec.org_id := update_base_tables_rec.org_id;
mo_global.init('ONT');
mo_global.set_policy_context(p_access_mode => 'S',
p_org_id => update_base_tables_rec.org_id);
hz_cust_account_site_v2pub.create_cust_acct_site(p_init_msg_list => 'T',
p_cust_acct_site_rec => l_cust_acct_site_rec,
x_cust_acct_site_id => l_num_obj_ver_num,
x_return_status => l_chr_sit_return_status,
x_msg_count => l_num_sit_msg_count,
x_msg_data => l_chr_sit_msg_data);
dbms_output.put_line('x_cust_acct_site_id: ' || l_num_obj_ver_num);
dbms_output.put_line('x_return_status: ' || l_chr_sit_return_status);
IF l_chr_sit_return_status != 'S' THEN
--Display all the error messages
FOR j IN 1 .. fnd_msg_pub.count_msg LOOP
dbms_output.put_line(j);
l_chr_sit_msg_data := fnd_msg_pub.get(p_msg_index => j,
p_encoded => 'F');
dbms_output.put_line('Site Message(' || j || '):= ' ||
l_chr_sit_msg_data);
END LOOP;
END IF;
BEGIN
SELECT cust_acct_site_id
INTO l_cust_acct_site_use_rec.cust_acct_site_id
FROM hz_cust_acct_sites_all
WHERE orig_system_reference = update_base_tables_rec.address_ref;
EXCEPTION
WHEN OTHERS THEN
l_cust_acct_site_use_rec.cust_acct_site_id := fnd_api.g_miss_num;
END;
l_cust_acct_site_use_rec.org_id := update_base_tables_rec.org_id;
l_cust_acct_site_use_rec.site_use_code := 'BILL_TO';
l_cust_acct_site_use_rec.status := 'A';
l_cust_acct_site_use_rec.primary_flag := 'Y';
l_cust_acct_site_use_rec.orig_system_reference := update_base_tables_rec.address_ref;
l_cust_acct_site_use_rec.created_by_module := 'HZ_CPUI';
mo_global.set_policy_context(p_access_mode => 'S',
p_org_id => update_base_tables_rec.org_id);
hz_cust_account_site_v2pub.create_cust_site_use(p_init_msg_list => 'T',
p_cust_site_use_rec => l_cust_acct_site_use_rec,
p_customer_profile_rec => l_customer_profile_rec,
p_create_profile => fnd_api.g_true,
p_create_profile_amt => fnd_api.g_true,
x_site_use_id => l_num_site_use_id,
x_return_status => l_chr_situ_return_status,
x_msg_count => l_num_situ_msg_count,
x_msg_data => l_chr_situ_msg_data);
dbms_output.put_line('x_site_use_id: ' || l_num_site_use_id);
dbms_output.put_line('x_return_status: ' || l_chr_situ_return_status);
IF l_chr_situ_return_status != 'S' THEN
--Display all the error messages
FOR j IN 1 .. fnd_msg_pub.count_msg LOOP
dbms_output.put_line(j);
l_chr_situ_msg_data := fnd_msg_pub.get(p_msg_index => j,
p_encoded => 'F');
dbms_output.put_line('Site Use Message(' || j || '):= ' ||
l_chr_situ_msg_data);
END LOOP;
END IF;
END LOOP;
END;
/

客户地点分配多OU的更多相关文章

  1. AR*客户地点分配OU

    DECLARE p_cust_acct_site_rec hz_cust_account_site_v2pub.cust_acct_site_rec_type; p_cust_site_use_rec ...

  2. Oracle EBS 更新客户地点

    --更新客户地点 declare x_return_status ); x_msg_count NUMBER; x_msg_data ); x_profile_id NUMBER; l_locatio ...

  3. Oracel数据库连接时出现:ORA-12518:监听程序无法分发客户机连

    在连接Oracel数据库时,每隔一段时间就会出现:ORA-12518:监听程序无法分发客户机连接,如图 上网查了资料原因和解决方案如下: 一.[问题描述] 最近,在系统高峰期的时候,会提示如上的错误, ...

  4. XShell提示Connection closed by foreign host的问题 和 路由器分配IP的规则

    情况是这样的: VMware中有三个Linux机器分别是crxy99(192.168.1.99),crxy100(192.168.1.100),crxy101(192.168.1.101),crxy1 ...

  5. EBS 客户表结构

     客户表/联系人/PARTY关联 HZ_PARTIES 客户账户表 HZ_CUST_ACCOUNTS SELECT hp.party_number --客户注册标识 , hp.party_name ...

  6. 客户信息全SQL

    SELECT hp.party_name "客户名称", --客户名称 hca.account_number "客户编号", --客户编号 hca.cust_a ...

  7. 使用ML.NET实现基于RFM模型的客户价值分析

    RFM模型 在众多的客户价值分析模型中,RFM模型是被广泛应用的,尤其在零售和企业服务领域堪称经典的分类手段.它的核心定义从基本的交易数据中来,借助恰当的聚类算法,反映出对客户较为直观的分类指示,对于 ...

  8. AEAI CRM V1.6.0 升级说明,开源客户关系管理系统

    1 升级说明 AEAI CRM v1.6.0版是AEAI CRM v1.5.2版客户关系管理系统的升级版本,本次版本是基于AEAI DP v3.8.0_20170228进行打包部署的,升级内容主要是针 ...

  9. oracle:TNS:监听程序无法分发客户机连接

    挂上vpn的时候,PL/SQL连接到oracle的时候,显示ORA-12518:监听程序无法分发客户机连接.如下图: 一.[问题描述] 最近,在系统高峰期的时候,会提示如上的错误,致使无法连接到服务器 ...

随机推荐

  1. 剑指架构师系列-持续集成之Maven实现项目的编译、发布和部署

    Maven组织项目进行编译.部署 Maven项目基本的结构说明如下: mazhi  // 控制所有荐的编译.部署.发布 mazhi-app-parent  // 项目的父项目,有一些公共的设置可以被子 ...

  2. JS中的DOM— —节点以及操作

    DOM操作在JS中可以说是非常常见了吧,很多网页的小功能的实现,比如一些元素的增删操作等都可以用JS来实现.那么在DOM中我们需要知道些什么才能完成一些功能的实现呢?今天这篇文章就先简单的带大家入一下 ...

  3. Node.js 模块

    稳定性: 5 - 锁定 Node 有简单的模块加载系统.在 Node 里,文件和模块是一一对应的.下面例子里,foo.js 加载同一个文件夹里的 circle.js 模块. foo.js 内容: va ...

  4. Python3 解释器

    Linux/Unix的系统上,Python解释器通常被安装在 /usr/local/bin/python3.4 这样的有效路径(目录)里. 我们可以将路径 /usr/local/bin 添加到您的Li ...

  5. Spring Boot+maven打war包

    存在一个坑: 官网文档 指出以下前3步做法,但是这样只可以打出可运行的jar包,要打出war包还要在文档后面的链接跳到另一个页面,才能找到第四步的做法,也就是最终能够打出war包,可能有些朋友有些粗心 ...

  6. SQLite Update 语句(http://www.w3cschool.cc/sqlite/sqlite-update.html)

    SQLite Update 语句 SQLite 的 UPDATE 查询用于修改表中已有的记录.可以使用带有 WHERE 子句的 UPDATE 查询来更新选定行,否则所有的行都会被更新. 语法 带有 W ...

  7. 19 主线程向子线程发送信息(handler)

    package com.fmy.handler; import android.app.Activity; import android.os.Bundle; import android.os.Ha ...

  8. 安卓程序员要拿到5000和1w的薪资,分别需要掌握哪些技术?

    这个是我在逛知乎的时候发现的一个帖子,在这里小小的整理了一下,收集了一些评论,然后我分享出来,希望对自己还有同行有所帮助. 著作权归作者所有. 商业转载请联系作者获得授权,非商业转载请注明出处. 链接 ...

  9. 【并发编程】Binder运行机制的流程图

    Binder工作在Linux层面,属于一个驱动,只是这个驱动不需要硬件,或者说其操作的硬件是基于一小段内存.从线程的角度来讲,Binder驱动代码运行在内核态,客户端程序调用Binder是通过系统调用 ...

  10. Android简易实战教程--第十五话《在外部存储中读写文件》

    第七话里面介绍了在内部存储读写文件 点击打开链接. 这样有一个比较打的问题,假设系统内存不够用,杀本应用无法执行,或者本应用被用户卸载重新安装后.以前保存的用户名和密码都不会得到回显.所以,有必要注意 ...