EBS 使用API更新物料属性 Inv_Item_Grp

29 篇文章 0 订阅

摘自:https://blog.51cto.com/baser/2164792

 

使用标准API Inv_Item_Grp 更新物料属性,可以修改大部分字段,包括物料编码、物料描述等属性。

不可修改字段:PRIMARY_UNIT_OF_MEASURE, TRACKING_QUANTITY_IND, ONT_PRICING_QTY_SOURCE, SECONDARY_UOM_CODE, SECONDARY_DEFAULT_IND, DUAL_UOM_DEVIATION_HIGH, DUAL_UOM_DEVIATION_LOW 和 ENGINEERING_ITEM_FLAG.

 

脚本如下:

DECLARE
    l_Item_Rec      Inv_Item_Grp.Item_Rec_Type;
    x_Item_Rec      Inv_Item_Grp.Item_Rec_Type;
    x_Error_Tbl     Inv_Item_Grp.Error_Tbl_Type;
    x_Return_Status VARCHAR2(1);
BEGIN

    Fnd_Global.Apps_Initialize(User_Id      => 0,
                               Resp_Id      => 20634,
                               Resp_Appl_Id => 401);

    --Item
    l_Item_Rec.Inventory_Item_Id := 3374628;
    l_Item_Rec.Organization_Id   := 176;

    --可修改:
    l_Item_Rec.Segment1 := 'CCITSpeed001-1';

    --不可修改字段:PRIMARY_UNIT_OF_MEASURE, TRACKING_QUANTITY_IND, ONT_PRICING_QTY_SOURCE, SECONDARY_UOM_CODE, SECONDARY_DEFAULT_IND, DUAL_UOM_DEVIATION_HIGH, DUAL_UOM_DEVIATION_LOW 和 ENGINEERING_ITEM_FLAG

    --API
    Inv_Item_Grp.Update_Item(p_Commit        => Fnd_Api.g_False,
                             p_Item_Rec      => l_Item_Rec,
                             x_Item_Rec      => x_Item_Rec,
                             x_Return_Status => x_Return_Status,
                             x_Error_Tbl     => x_Error_Tbl);

    Dbms_Output.Put_Line('x_Return_Status:' || x_Return_Status);

    --Result
    IF x_Return_Status <> Fnd_Api.g_Ret_Sts_Success THEN
    
        -- ROLLBACK;
        FOR i IN 1 .. x_Error_Tbl.Count LOOP
            Dbms_Output.Put_Line('Transaction ID   :' || x_Error_Tbl(i)
                                 .Transaction_Id);
            Dbms_Output.Put_Line('Unique ID           :' || x_Error_Tbl(i)
                                 .Unique_Id);
            Dbms_Output.Put_Line('Message Name  :' || x_Error_Tbl(i)
                                 .Message_Name);
            Dbms_Output.Put_Line('Message Text:     :' || x_Error_Tbl(i)
                                 .Message_Text);
            Dbms_Output.Put_Line('Table Name        :' || x_Error_Tbl(i)
                                 .Table_Name);
            Dbms_Output.Put_Line('Column Name   :' || x_Error_Tbl(i)
                                 .Column_Name);
            Dbms_Output.Put_Line('Organization ID :' || x_Error_Tbl(i)
                                 .Organization_Id);
        END LOOP;
    
        IF (x_Return_Status = Fnd_Api.g_Ret_Sts_Unexp_Error) THEN
            RAISE Fnd_Api.g_Exc_Unexpected_Error;
        ELSIF (x_Return_Status = Fnd_Api.g_Ret_Sts_Error) THEN
            RAISE Fnd_Api.g_Exc_Error;
        END IF;
    
    ELSE
        -- COMMIT;
        Dbms_Output.Put_Line('ok:' || x_Item_Rec.Item_Number);
    END IF;

END;

 

已测试。

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值