我是靠谱客的博主 花痴毛豆,最近开发中收集的这篇文章主要介绍OE_HOLDS_PUB.RELEASE_HOLDS -- Release Holds Script,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

Below script will help you to Release Order level or Line Level hold in Oracle Order Management through API OE_HOLDS_PUB . RELEASE_HOLDS

This script was tested in R12.1.1 

SET serveroutput ON;
DECLARE

v_return_status    VARCHAR2 ( 30 );
v_msg_data         VARCHAR2 ( 4000 );
v_msg_count        NUMBER ;
v_order_tbl        OE_HOLDS_PVT . order_tbl_type ;
v_hold_id          NUMBER DEFAULT 50 ;
v_header_id        NUMBER DEFAULT 1705 ;

v_context          VARCHAR2 ( 2 );

FUNCTION set_context ( i_user_name    IN   VARCHAR2
                     , i_resp_name    IN   VARCHAR2
                     , i_org_id       IN   NUMBER )
RETURN VARCHAR2
IS
BEGIN
  NULL;
    -- In order to reduce the content of the post I moved the implementation part of this function to another post and it is   available   here   
END set_context ;
 
BEGIN

-- Setting the context ----

v_context := set_context ( '&user' , '&responsibility' , 2038 );
IF v_context = 'F'
   THEN
   DBMS_OUTPUT . put_line ( 'Error while setting the context' );
END IF;

--- context done ------------

BEGIN

v_order_tbl ( 1 ). header_id           := v_header_id ;
v_return_status                    := NULL;
v_msg_data                         := NULL;
v_msg_count                        := NULL;

dbms_output . put_line ( 'Calling the API to Release hold' );

OE_HOLDS_PUB . RELEASE_HOLDS (
                         p_api_version         => 1.0 ,
                         p_order_tbl           => v_order_tbl ,
                         p_hold_id             => v_hold_id ,
                         p_release_reason_code => 'AR_AUTOMATIC' ,
                         p_release_comment     => 'TESTING' ,
                         x_return_status       => v_return_status ,
                         x_msg_count           => v_msg_count ,
                         x_msg_data            => v_msg_data
                           );


IF v_return_status = FND_API . G_RET_STS_SUCCESS THEN
dbms_output . put_line ( 'success:' );
COMMIT;
ELSIF v_return_status IS NULL THEN
dbms_output . put_line ( 'Status is null' );
ELSE
dbms_output . put_line ( 'Failed: ' || v_msg_data );


FOR i IN 1 .. oe_msg_pub . count_msg
     LOOP
        v_msg_data := oe_msg_pub . get ( p_msg_index => i , p_encoded => 'F' );
        dbms_output . put_line ( i|| ') ' || v_msg_data );
     END LOOP ;
    
ROLLBACK;
END IF;

EXCEPTION
WHEN OTHERS THEN
 dbms_output . put_line ( 'Error is ' || SQLCODE || '---' || SQLERRM);
END;

最后

以上就是花痴毛豆为你收集整理的OE_HOLDS_PUB.RELEASE_HOLDS -- Release Holds Script的全部内容,希望文章能够帮你解决OE_HOLDS_PUB.RELEASE_HOLDS -- Release Holds Script所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(70)

评论列表共有 0 条评论

立即
投稿
返回
顶部