物料事務處理接口表 MTL_TRANSACTIONS_INTERFACE 賬戶別名使用 及 提示無效的分配賬戶字段


實例:

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、系統在提交請求時會按照請求所提交的職責進行安全性驗證(這就是我們在程序包調用請求時需要先初始化職責的原因)。

結論:

由以上分析可以得出,事務處理接口表中的數據在驗證和處理時與請求提交的職責安全性驗證有關,與數據錄入的職責無關。

所以在提交公共的接口處理及工作流處理請求時,一定要使用全訪問的安全性校驗的職責否則就會出現問題。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM