根据ccid取得账户,更改某段值再创建账户,返回新的ccid
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的更多相关文章
- DirectoryEntry 账户启动与停用 以及创建账户等
启动账户: DirectoryEntry usr = new DirectoryEntry("LDAP://CN=New User,CN=users,DC=fabrikam,DC=com&q ...
- 一段小代码秒懂C++右值引用和RVO(返回值优化)的误区
关于C++右值引用的参考文档里面有明确提到,右值引用可以延长临时变量的周期.如: std::string&& r3 = s1 + s1; // okay: rvalue referen ...
- 【shell脚本】创建账户及删除账户,批量创建账户及批量删除账户===autoCreateUser.sh
一.字符串运算符 二.创建账户 1.提示用户输入用户名和密码,脚本自动创建相应的账户及配置密码.如果用户不输入账户名,则提示必须输入账户名并退出脚本;如果用户不输入密码,则统一使用默认的 123456 ...
- 一段完整的创建表格的SQL代码
一段完整的创建表格的SQL代码 使用SQL语句创建一张表,不仅可以可以快速熟悉SQL语句,还可以从这看出一个人对该技能点的熟悉程度. 这里先说明几点: PRIMARY KEY:主键,一张表中只允许有一 ...
- 编写Java程序,使用ThreadLocal类,项目中创建账户类 Account,类中包括账户名称name、 ThreadLocal 类的引用变量amount,表示存款
查看本章节 查看作业目录 需求说明: 某用户共有两张银行卡,账户名称相同,但卡号和余额不同.模拟用户使用这两张银行卡进行消费的过程,并打印出消费明细 实现思路: 项目中创建账户类 Account,类中 ...
- C#进阶系列——WebApi 接口返回值不困惑:返回值类型详解
前言:已经有一个月没写点什么了,感觉心里空落落的.今天再来篇干货,想要学习Webapi的园友们速速动起来,跟着博主一起来学习吧.之前分享过一篇 C#进阶系列——WebApi接口传参不再困惑:传参详解 ...
- 【已解决】关于SQL2008 “不允许保存更改。您所做的更改要求删除并重新创建以下表。您对无法重新创建的标进行了更改或者启用了‘阻止保存要求重新创建表的更改’” 解决方案
近日在使用SQL Server 2008的过程中,修改已创建完成的表结构时,却一直提示弹出如下提示: 不允许保存更改.您所做的更改要求删除并重新创建以下表.您对无法重新创建的标进行了更改或者启用了“阻 ...
- excel转化为table(去掉所有列值都为空的值一行,即返回有效值的DataTable)
/// <summary> /// 去掉所有列值都为空的值一行,即返回有效值的DataTable /// </summary> /// <param name=" ...
- 关于SQL2008 “不允许保存更改。您所做的更改要求删除并重新创建以下表。您对无法重新创建的标进行了更改或者启用了‘阻止保存要求重新创建表的更改’” 解决方案
不允许保存更改.您所做的更改要求删除并重新创建以下表.您对无法重新创建的标进行了更改或者启用了“阻止保存要求重新创建表的更改” 解决方法: 打开SQL SERVER 2008 工具-->选项- ...
随机推荐
- python的变量与赋值
1.变量的命名规则 变量其实通过一个标记调用内存中的值,而变量名就是这个标记的名称,但是万一这个标记已经被提前占用或者解释器认为这个标记是不合法的,那么就会报错.下面总结了一下变量的命名规则: 1.不 ...
- 第三届“百越杯”福建省高校网络空间安全大赛_Do you know upload?
题目在i春秋的ctf训练营 既然是上传,那就直接抓包 二话不说上来先给个00截断传个一句话助助兴 直接就成功了.... 赶紧操起菜刀去连接 进去之后发现ctf.sql是个空文件,那么flag应该在数据 ...
- ●Joyoi 收集邮票
题链: http://www.joyoi.cn/problem/tyvj-2325题解.1: 期望dp,(平方的期望不等于期望的平方...) 在这个题上坑了好久,也算是对期望的理解又深了一些. 很好的 ...
- hdu1698 线段树区间更新
Just a Hook Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
- bzoj3831 [Poi2014]Little Bird 单调队列优化dp
3831: [Poi2014]Little Bird Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 505 Solved: 322[Submit][ ...
- this指针是什么?
this指针的用处: 一个对象的this指针并不是对象本身的一部分.不会影响sizeof(对象)的结果.this的作用域在类内部,当在类的非静态成员函数中访问类的非静态成员的时候,编译器会自动将对象本 ...
- SQL Server2008 安装失败后的解决办法
SQL Server2008 安装不容易成功,或许用这种方法可能会安装成功. 首先,把电脑上的SQL Server2008 卸载干净 怎么卸载干净? 1.找到控制面板-->卸载程序--& ...
- if else与switch区别
一.if-else 只是单纯地一个接一个比较:if...else每个条件都计算一遍: 二.switch 使用了Binary Tree算法:绝大部分情况下switch会快一点,除非是if-else的第一 ...
- Redis实现单点登录
http://blog.csdn.net/WuCourage/article/details/77802812
- IScroll.js 学习笔记
一.css部分1.transform 旋转div { transform:rotate(7deg); -ms-transform:rotate(7deg); /* IE 9 */ -moz-trans ...