CREATE OR REPLACE PACKAGE cux_cuxaprebate_utl IS

  * ===============================================
* PROGRAM NAME:
* cux_price_utl_pkg
* DESCRIPTION:
* CUX:应付发票平台返利开发FORM 工具包
* HISTORY:
* 1.00 2013-12-01 cxy
* ==============================================*/
/* =============================================
* FUNCTION / PROCEDURE
* create_account
* DESCRIPTION:
* 根据ccid取得账户,更改某段值再创建账户,返回新的ccid
* ARGUMENT:
p_sql_stmt :动态SQL语句
* RETURN:
* N/A
* HISTORY:
* 1.00 2013-12-01 cxy
* =============================================*/
PROCEDURE create_account(p_org_id IN NUMBER,
p_ccid IN NUMBER,
x_ccid OUT NUMBER); END cux_cuxaprebate_utl;
/
CREATE OR REPLACE PACKAGE BODY cux_cuxaprebate_utl IS
-- Constant Variable
g_pkg_name CONSTANT VARCHAR2(30) := 'cux_CUXAPREBATE_utl';
g_conc_request_id CONSTANT NUMBER := fnd_global.conc_request_id;
g_login_id NUMBER := fnd_global.conc_login_id;
g_user_id NUMBER := fnd_global.user_id;
g_prog_appl_id NUMBER := fnd_global.prog_appl_id;
g_prog_id NUMBER := fnd_global.conc_program_id;
g_request_id CONSTANT NUMBER := fnd_global.conc_request_id;
g_conc_program_id CONSTANT NUMBER := fnd_global.conc_program_id;
-- Global constant variable
g_debug_flag VARCHAR2(1) := nvl(fnd_profile.value('AFLOG_ENABLED'), 'N');
g_bg_id CONSTANT NUMBER := fnd_profile.value('PER_BUSINESS_GROUP_ID');
TYPE account_type IS TABLE OF VARCHAR2(20) INDEX BY BINARY_INTEGER;
v_account_type account_type;
/* =============================================
* FUNCTION / PROCEDURE
* create_account
* DESCRIPTION:
* 根据ccid取得账户,更改某段值再创建账户,返回新的ccid
* ARGUMENT:
p_org_id :OU ID
p_ccid :原ccid
x_ccid :生成新的ccid
* RETURN:
* N/A
* HISTORY:
* 1.00 2013-12-01 cxy
* =============================================*/
PROCEDURE create_account(p_org_id IN NUMBER,
p_ccid IN NUMBER,
x_ccid OUT NUMBER) IS
comma_location NUMBER := 0;
v_location VARCHAR2(100);
v_count NUMBER := 0;
account VARCHAR2(100) := '06.0.212101.0.0.0.0';
account_adj VARCHAR2(100);
prev_location NUMBER := 0;
v_account VARCHAR2(100);
x_account VARCHAR2(100); p_segment1 VARCHAR2(30);
p_segment2 VARCHAR2(30);
p_segment3 VARCHAR2(30);
p_segment4 VARCHAR2(30);
p_segment5 VARCHAR2(30);
p_segment6 VARCHAR2(30);
p_segment7 VARCHAR2(30);
--x_ccid NUMBER;
v_segment3 VARCHAR2(30);
BEGIN
--在最后一个段后面加一个点
account := cux_flex_pkg.get_gl_flexfields(p_ccid => p_ccid,
p_return => 'A');
account_adj := account || '.';
LOOP
v_count := v_count + 1;
comma_location := instr(account_adj, '.', comma_location + 1);
EXIT WHEN comma_location = 0;
v_location := substr(account_adj,
prev_location + 1,
comma_location - prev_location - 1);
prev_location := comma_location;
v_account_type(v_account_type.count + 1) := v_location; END LOOP;
SELECT attribute1
INTO v_segment3
FROM cux_lookup_codes v
WHERE v.lookup_type = 'CUX_PUBLIC_ACCOUNT_DEFINE'
AND v.enabled_flag = 'Y'
AND v.lookup_code = 'AP_REBATE_MD';
v_account_type(3) := v_segment3;
FOR i IN v_account_type.first .. v_account_type.last LOOP
IF i = 1 THEN
p_segment1 := v_account_type(i);
ELSIF i = 2 THEN
p_segment2 := v_account_type(i);
ELSIF i = 3 THEN
p_segment3 := v_account_type(i);
ELSIF i = 4 THEN
p_segment4 := v_account_type(i);
ELSIF i = 5 THEN
p_segment5 := v_account_type(i);
ELSIF i = 6 THEN
p_segment6 := v_account_type(i);
ELSIF i = 7 THEN
p_segment7 := v_account_type(i);
END IF;
END LOOP; x_ccid := cux_gl_public_pkg.get_code_combination_id(p_org_id => 101,
p_segment1 => p_segment1,
p_segment2 => p_segment2,
p_segment3 => p_segment3,
p_segment4 => p_segment4,
p_segment5 => p_segment5,
p_segment6 => p_segment6,
p_segment7 => p_segment7);
/* dbms_output.put_line(x_ccid);*/
END; END cux_cuxaprebate_utl;
/

根据ccid取得账户,更改某段值再创建账户,返回新的ccid的更多相关文章

  1. DirectoryEntry 账户启动与停用 以及创建账户等

    启动账户: DirectoryEntry usr = new DirectoryEntry("LDAP://CN=New User,CN=users,DC=fabrikam,DC=com&q ...

  2. 一段小代码秒懂C++右值引用和RVO(返回值优化)的误区

    关于C++右值引用的参考文档里面有明确提到,右值引用可以延长临时变量的周期.如: std::string&& r3 = s1 + s1; // okay: rvalue referen ...

  3. 【shell脚本】创建账户及删除账户,批量创建账户及批量删除账户===autoCreateUser.sh

    一.字符串运算符 二.创建账户 1.提示用户输入用户名和密码,脚本自动创建相应的账户及配置密码.如果用户不输入账户名,则提示必须输入账户名并退出脚本;如果用户不输入密码,则统一使用默认的 123456 ...

  4. 一段完整的创建表格的SQL代码

    一段完整的创建表格的SQL代码 使用SQL语句创建一张表,不仅可以可以快速熟悉SQL语句,还可以从这看出一个人对该技能点的熟悉程度. 这里先说明几点: PRIMARY KEY:主键,一张表中只允许有一 ...

  5. 编写Java程序,使用ThreadLocal类,项目中创建账户类 Account,类中包括账户名称name、 ThreadLocal 类的引用变量amount,表示存款

    查看本章节 查看作业目录 需求说明: 某用户共有两张银行卡,账户名称相同,但卡号和余额不同.模拟用户使用这两张银行卡进行消费的过程,并打印出消费明细 实现思路: 项目中创建账户类 Account,类中 ...

  6. C#进阶系列——WebApi 接口返回值不困惑:返回值类型详解

    前言:已经有一个月没写点什么了,感觉心里空落落的.今天再来篇干货,想要学习Webapi的园友们速速动起来,跟着博主一起来学习吧.之前分享过一篇 C#进阶系列——WebApi接口传参不再困惑:传参详解  ...

  7. 【已解决】关于SQL2008 “不允许保存更改。您所做的更改要求删除并重新创建以下表。您对无法重新创建的标进行了更改或者启用了‘阻止保存要求重新创建表的更改’” 解决方案

    近日在使用SQL Server 2008的过程中,修改已创建完成的表结构时,却一直提示弹出如下提示: 不允许保存更改.您所做的更改要求删除并重新创建以下表.您对无法重新创建的标进行了更改或者启用了“阻 ...

  8. excel转化为table(去掉所有列值都为空的值一行,即返回有效值的DataTable)

    /// <summary> /// 去掉所有列值都为空的值一行,即返回有效值的DataTable /// </summary> /// <param name=" ...

  9. 关于SQL2008 “不允许保存更改。您所做的更改要求删除并重新创建以下表。您对无法重新创建的标进行了更改或者启用了‘阻止保存要求重新创建表的更改’” 解决方案

    不允许保存更改.您所做的更改要求删除并重新创建以下表.您对无法重新创建的标进行了更改或者启用了“阻止保存要求重新创建表的更改” 解决方法:  打开SQL SERVER 2008 工具-->选项- ...

随机推荐

  1. 【Swfit】Swift与OC两种语法写单例的区别

    Swift与OC两种语法写单例的区别 例如写一个NetworkTools的单例 (1)OC写单例 + (instancetype)sharedNetworkTools { static id inst ...

  2. 医疗器械c#上位机开发指引教程

    此教程面向的读者:对医疗器械上位机编程有兴趣,或者急需了解医疗器械(尿常规.血液分析.生化.心电.B超等医疗下位仪器)的编程流程.编程细节的程序员. 1.得到仪器协议 当我们需要与医疗器械等下位机数据 ...

  3. 双边滤波算法的简易实现bilateralFilter

    没怎么看过双边滤波的具体思路,动手写一写,看看能不能突破一下. 最后,感觉算法还是要分开 水平 与 垂直 方向进行分别处理,才能把速度提上去. 没耐性写下去了,发上来,给大伙做个参考好了. 先上几张效 ...

  4. bzoj 3924: [Zjoi2015]幻想乡战略游戏

    Description 傲娇少女幽香正在玩一个非常有趣的战略类游戏,本来这个游戏的地图其实还不算太大,幽香还能管得过来,但是不知道为什么现在的网游厂商把游戏的地图越做越大,以至于幽香一眼根本看不过来, ...

  5. bzoj 3672: [Noi2014]购票

    Description 今年夏天,NOI在SZ市迎来了她30周岁的生日.来自全国 n 个城市的OIer们都会从各地出发,到SZ市参加这次盛会. 全国的城市构成了一棵以SZ市为根的有根树,每个城市与它的 ...

  6. 2015 多校联赛 ——HDU5294(最短路,最小切割)

    Tricks Device Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) To ...

  7. 【NOIP2004】虫食算

    Description 所谓虫食算,就是原先的算式中有一部分被虫子啃掉了,需要我们根据剩下的数字来判定被啃掉的字母.来看一个简单的例子: 43#9865#045 +. 8468#6633 444455 ...

  8. 【Toll!Revisited(uva 10537)】

    题目来源:蓝皮书P331 ·这道题使得我们更加深刻的去理解Dijkstra!       在做惯了if(dis[u]+w<dis[v])的普通最短路后,这道选择路径方案不是简单的比大小的题横在了 ...

  9. hdu 3016 dp+线段树

    Man Down Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total S ...

  10. [bzoj4151][AMPPZ2014]The Cave

    来自FallDream的博客,未经允许,请勿转载,谢谢. 给定一棵有n个节点的树,相邻两点之间的距离为1. 请找到一个点x,使其满足所有m条限制,其中第i条限制为dist(x,a[i])+dist(x ...