实例:

PROCEDURE MAIN(P_ORGANIZATION_ID NUMBER,
P_PERIOD_NAME VARCHAR2,
XV_STATUS OUT VARCHAR,
XV_MESG OUT VARCHAR2) IS
CURSOR LCUR_ADJUST IS
SELECT COQ.TRX_ID,
COQ.ORGANIZATION_ID,
COQ.ITEM_ID,
MTL.PRIMARY_UOM_CODE,
COQ.SUBINVENTORY_CODE,
COQ.LOCATOR_ID,
COQ.LOT_NUMBER,
(COQ.CHECK_QTY-COQ.ONHAND_QTY) ADJUST_QTY,
COQ.PERIOD_NAME
FROM CUX_ONHAND_QTY_ADJUST_T COQ
JOIN MTL_SYSTEM_ITEMS_B MTL
ON MTL.INVENTORY_ITEM_ID=COQ.ITEM_ID
AND MTL.ORGANIZATION_ID=COQ.ORGANIZATION_ID
WHERE COQ.ORGANIZATION_ID=P_ORGANIZATION_ID
AND COQ.PERIOD_NAME=P_PERIOD_NAME
AND NVL(COQ.IMPORT_FLAG,'N')='N'
AND COQ.ONHAND_QTY<>COQ.CHECK_QTY;
lv_transaction_date DATE;
lv_distribution_account_id NUMBER;
lv_transaction_source_id NUMBER;
ln_txn_type_id NUMBER;
ln_period_id number;
ln_txn_source_type_id NUMBER :=6;
l_iface_rec inv.mtl_transactions_interface%ROWTYPE;
l_iface_lot_rec inv.mtl_transaction_lots_interface%ROWTYPE;
BEGIN
XV_STATUS:='S';
BEGIN
SELECT GP.SCHEDULE_CLOSE_DATE,GP.ACCT_PERIOD_ID INTO lv_transaction_date,ln_period_id FROM org_acct_periods GP
WHERE GP.PERIOD_NAME=P_PERIOD_NAME
AND GP.ORGANIZATION_ID=P_ORGANIZATION_ID
AND GP.open_flag = 'Y'
AND GP.PERIOD_SET_NAME='ZH_GL_PERIOD';
EXCEPTION
WHEN OTHERS THEN
XV_STATUS:='E';
XV_MESG:=XV_MESG||'获取期间日期出现错误!';
END;
IF lv_transaction_date>SYSDATE THEN
lv_transaction_date:=SYSDATE;
END IF;
BEGIN
SELECT distribution_account, disposition_id
INTO lv_distribution_account_id, lv_transaction_source_id
FROM mtl_generic_dispositions
WHERE organization_id = P_ORGANIZATION_ID
AND segment1 LIKE '%在线盈亏'
AND disable_date IS NULL
AND effective_date <= SYSDATE
AND ROWNUM=1;
EXCEPTION
WHEN OTHERS THEN
XV_STATUS:='E';
XV_MESG:=XV_MESG||'账户别名类型出现错误!';
END;
IF XV_STATUS<>'E' THEN
FOR LC IN LCUR_ADJUST LOOP
IF LC.ADJUST_QTY>0 THEN
ln_txn_type_id:=41;--账户别名接收
ELSE
ln_txn_type_id:=31;--账户别名发放
END IF;
SELECT mtl_material_transactions_s.nextval
INTO l_iface_rec.transaction_interface_id
FROM dual;
l_iface_rec.last_update_date := SYSDATE;
l_iface_rec.last_updated_by := FND_GLOBAL.USER_ID;
l_iface_rec.creation_date := SYSDATE;
l_iface_rec.created_by := FND_GLOBAL.USER_ID;
l_iface_rec.last_update_login := -1;
l_iface_rec.transaction_header_id := l_iface_rec.transaction_interface_id;
l_iface_rec.transaction_mode := 3;
l_iface_rec.process_flag := 1;
l_iface_rec.transaction_type_id := ln_txn_type_id;
l_iface_rec.transaction_source_id := lv_transaction_source_id;
l_iface_rec.Transaction_Source_Type_Id :=ln_txn_source_type_id;
l_iface_rec.organization_id := LC.ORGANIZATION_ID;
l_iface_rec.inventory_item_id := LC.ITEM_ID;
l_iface_rec.locator_id :=LC.LOCATOR_ID;
l_iface_rec.subinventory_code := LC.SUBINVENTORY_CODE;
l_iface_rec.transaction_quantity := LC.ADJUST_QTY;
l_iface_rec.Primary_Quantity := LC.ADJUST_QTY;
l_iface_rec.transaction_uom := LC.PRIMARY_UOM_CODE;
l_iface_rec.transaction_date := lv_transaction_date;
l_iface_rec.acct_period_id :=ln_period_id;
l_iface_rec.source_code := '库存期末调整';
l_iface_rec.source_header_id := l_iface_rec.transaction_interface_id;
l_iface_rec.source_line_id := LC.TRX_ID;
--l_iface_rec.distribution_account_id:=lv_distribution_account_id;
INSERT INTO inv.mtl_transactions_interface VALUES l_iface_rec;
IF LC.LOT_NUMBER IS NOT NULL THEN
l_iface_lot_rec.transaction_interface_id := l_iface_rec.transaction_interface_id;
l_iface_lot_rec.lot_number := LC.LOT_NUMBER;
l_iface_lot_rec.transaction_quantity := l_iface_rec.transaction_quantity;
l_iface_lot_rec.source_code := l_iface_rec.source_code;
l_iface_lot_rec.source_line_id := l_iface_rec.source_line_id;
END IF;
UPDATE CUX_ONHAND_QTY_ADJUST_T COQA SET COQA.IMPORT_FLAG='Y' WHERE COQA.TRX_ID=LC.TRX_ID;
END LOOP;
COMMIT;
DELETE CUX_ONHAND_QTY_ADJUST_T COQ WHERE COQ.IMPORT_FLAG IS NULL;
COMMIT;
END IF;
EXCEPTION
WHEN OTHERS THEN
ROLLBACK;
XV_STATUS:='E';
XV_MESG:=XV_MESG||'数据插入接口出现错误!';
END;

插入接口表数据后,系统会使用计划的请求“库存事务处理工作流程” 和“处理事务处理接口” (接口管理中提交)对数据进行验证和处理

遇到问题:分配账户字段无效

原因分析:

1、刚开始处理以为是账户组合被失效,检查每个账户字段未发现失效的段。然后通过系统标准的杂项事物处理功能操作账户别名,同样的账户别名可以正常操作,正常产生分配。

3、考虑可能由账户安全性问题导致,但是用具体可操作的职责在事务处理接口界面查到后重新提交,发现仍有问题。

2、后查看请求“库存事务处理工作流程” 和“处理事务处理接口” ,发现这两个请求是由一个单一访问库存组织的职责提交。可访问的公司段为102,但出错的事务处理账户分配公司段是101,由此得出错误出现的原因。

3、系统在提交请求时会按照请求所提交的职责进行安全性验证(这就是我们在程序包调用请求时需要先初始化职责的原因)。

结论:

由以上分析可以得出,事务处理接口表中的数据在验证和处理时与请求提交的职责安全性验证有关,与数据录入的职责无关。

所以在提交公共的接口处理及工作流处理请求时,一定要使用全访问的安全性校验的职责否则就会出现问题。

物料事务处理接口表 MTL_TRANSACTIONS_INTERFACE 账户别名使用 及 提示无效的分配账户字段的更多相关文章

  1. INV*账户别名接收发放

    DECLARE --p_old_new_flag OLD 为导出 NEW 为导入 l_iface_rec inv.mtl_transactions_interface%ROWTYPE; l_iface ...

  2. 根据ccid取得账户,更改某段值再创建账户,返回新的ccid

    CREATE OR REPLACE PACKAGE cux_cuxaprebate_utl IS * =============================================== * ...

  3. win10访问共享文件夹提示:引用的账户当前已锁定,且当前可能无法登陆

    最近一台电脑访问windows 2008 R2 server的共享文件夹.没有使用域环境. win10界面提示:引用的账户当前已锁定,且当前可能无法登陆. 登陆2008发现,该账户的确锁定.猜测可能该 ...

  4. 物料事务处理interface与temp解析

    MTL_TRANSACTIONS_INTERFACE MTL_TRANSACTIONS_INTERFACE is the interface point between non– Inventory ...

  5. INV 调试: 如何获取库存物料事务处理调试信息

     1. 按如下方式设置系统配置文件值: 系统配置文件值 地点/用户/应用/职责层配置文件值 --汇总 FND: 启用调试日志   是 FND:调试日志层级   陈述 INV: 调试跟踪: 是 IN ...

  6. 【EBS】取数SQL-平均成本更新的物料事务处理追溯到应付发票

    SELECT hou.name,--组织 aia.invoice_num,--发票编号 msib.segment1,--物料编码 mmt.transaction_id--物料事务处理 FROM mtl ...

  7. windows 10微软账户不能访问局域网共享,但是本地账户可以访问

    windows10有时候无法访问局域网的共享文件夹.会提示没有权限. 如果共享的文件夹已经设置为everyone,那么通常是windows 10用的是微软账户登录的. 有两个方案可以处理这种情况. 一 ...

  8. win10 设定计划任务时提示所指定的账户名称无效,如何解决?

    我想把我的 python 爬虫脚本设定为自动定时执行,我的设备是win10 操作系统,这将用到系统自带的计划任务功能.且我希望不管用户是否登录都要运行该定时任务,但在设置计划任务的属性时,遇到一个报错 ...

  9. 待研究:insert客商账户触发器增加条件提示为空

    增加客商时候重名不给保存,增加修改条件提示找不到

随机推荐

  1. T-SQL查询语句(二):嵌套查询

    一个select...From...Where查询语句块可以嵌套在另一个select...From...Where查询块的Where子句中,称为嵌套查询.外层查询称为父查询,主查询.内层查询称为子查询 ...

  2. Web前端Require.js

    前言 前段时间粗略的扫过一次require.js,当时没怎么在意,结果昨天看到index里面的代码就傻了,完全不知道从哪开始看啦,所以require与backbone的学习还要加紧才行. 由于前端所占 ...

  3. WPF4.5新特性(MSDN的翻译读不太懂)

    WPF4.5新特性(MSDN的翻译读不太懂) 1. 新的Doctype声明 XHTML的声明太长了,我相信很少会有前端开发人员能手写出这个Doctype声明. <!DOCTYPE html PU ...

  4. Centos 5上使用YUM安装GIT

    网上搜索的基本上都是一样的内容 1.先安装git依赖的包 yum install zlib-devel yum install openssl-devel yum install perl yum i ...

  5. php memcached缓存集群

    一.需求描述 一linode xen vps 1G RAM,40+sites,IO频繁,openfiles ulimit已65535 US时间访问量大增,nginx不定时502 二.解决办法 page ...

  6. JAVA的abstract修饰符 && 接口interface用法 && 抽象类和interface的差别

    abstract修饰符可以修饰类和方法. (1)abstract修饰类,会使这个类成为一个抽象类,这个类将不能生成对象实例,但可以做为对象变量声明的类型(见后面实例),也就是编译时类型.抽象类就相当于 ...

  7. 初级FTP搭建

    一:了解FTP基本知识 Vsftpd 1.什么是FTP? File Transfer Protocol 基于C/S结构的文件传输协议2.使用什么协议?什么端口? TCP 21 建立命令链路 TCP 2 ...

  8. 浅谈java垃圾回收机制

    今天看thinking in java,里面很详细的谈到java垃圾回收器机制,看完后让我对这神秘的区域有一定的了解,特写一些小总结记录下来. 分两点来说. 第一点:Object.finalize() ...

  9. XAF-Domain Components 技术 使用接口来定义ORM业务对象

    一.简介 Domain Component组件技术,以下简称DC,是扩展自XPO的, 官方不建议新手使用DC. 如果你用过EF,XPO及类似的ORM,这是很容易理解的,DC是基于XPO的,只是原业定义 ...

  10. asp.net MVC 模拟实现与源码分析

    前言 本文流程#1: 从一个空项目->模拟实现一个从/Home/Test形式的URL敲入->后台逻辑处理->传入后台model参数->调用razor引擎->前台展示 涉及 ...