0

我使用以下 API 将多个项目(一个接一个)从一个组织分配给另一个组织。我使用主项目窗口通过库存责任创建了测试项目,然后使用以下代码将它们分配给另一个组织:

BEGIN 
DECLARE 
l_api_version NUMBER := 1.0; 
l_init_msg_list VARCHAR2(2) := FND_API.G_TRUE; 
l_commit VARCHAR2(2) := FND_API.G_FALSE; 
x_message_list error_handler.error_tbl_type; 
itemid mtl_system_items_b.inventory_item_id %TYPE; 
segment1 mtl_system_items_b.segment1 %TYPE; 
primary_uom_code mtl_system_items_b.primary_uom_code %TYPE; 
x_return_status VARCHAR2(2); 
x_msg_count NUMBER := 0; 
BEGIN 
SELECT inventory_item_id INTO itemid FROM mtl_system_items_b WHERE inventory_item_id=2447106 and organization_id=116; 
SELECT segment1 
INTO segment1 FROM mtl_system_items_b WHERE inventory_item_id=2447106 and organization_id=116; 
SELECT primary_uom_code INTO primary_uom_code FROM mtl_system_items_b WHERE inventory_item_id=2447106 and organization_id=116; 

EGO_ITEM_PUB.ASSIGN_ITEM_TO_ORG( 
P_API_VERSION => l_api_version 
, P_INIT_MSG_LIST => l_INIT_MSG_LIST 
, P_COMMIT => l_COMMIT 
, P_INVENTORY_ITEM_ID => itemid --(item id from the above Query) 
, P_ITEM_NUMBER => segment1 --(Item Code from the above Query) 
, P_ORGANIZATION_ID => 117 --(Organization Id for assingment) 
, P_ORGANIZATION_CODE => 'D12'--v_organization_code 
, P_PRIMARY_UOM_CODE =>primary_uom_code --(UOM from the above Query) 
, X_RETURN_STATUS => X_RETURN_STATUS 
, X_MSG_COUNT => X_MSG_COUNT 
); 
DBMS_OUTPUT.PUT_LINE('Status: '||x_return_status); 
IF (x_return_status <> FND_API.G_RET_STS_SUCCESS) THEN 
DBMS_OUTPUT.PUT_LINE('Error Messages :'); 
Error_Handler.GET_MESSAGE_LIST(x_message_list=> x_message_list); 
FOR j IN 1..x_message_list.COUNT LOOP 
DBMS_OUTPUT.PUT_LINE(x_message_list(j).message_tex t); 
END LOOP; 
END IF; 
EXCEPTION 
WHEN OTHERS THEN 
dbms_output.put_line('Exception Occured :'); 
DBMS_OUTPUT.PUT_LINE(SQLCODE ||':'||SQLERRM); 

END; 
END; 

完成后,我检查了数据库并将项目分配给我想要的组织。但是,当我通过我分配的新组织下的 GUI(项目信息窗口或项目搜索窗口)搜索时,这些项目没有出现在任何窗口中。

我尝试更改一些看起来异常的值(例如:上次更新时间是“-1”,可能是因为我使用 API 而不是使用我的用户 ID 和密码的 GUI)。

为什么这些项目没有出现在 GUI 中?除了正确执行上述代码之外,我还缺少其他步骤吗?请帮忙。

4

1 回答 1

1

您没有提交交易。您声明:

l_commit VARCHAR2(2) := FND_API.G_FALSE; 

然后将其传递给 API。如果您随后使用相同的事务查询表,您将看到修改后的数据。但是申请表正在使用另一个会话。

您需要在最后添加一个提交。至于是否传入G_TRUE,需要阅读API文档。

于 2013-11-04T06:21:25.123 回答