DECLARE
CURSOR c1
IS
SELECT batch_id, sysdate -1 actual_cmplt_date, sysdate-1 batch_close_date
FROM gme_batch_header
WHERE batch_status = 2;
l_batch_header_rec gme_batch_header%ROWTYPE;
x_batch_header_rec gme_batch_header%ROWTYPE;
x_message_count NUMBER := 0;
x_message_list VARCHAR2 (4000) := NULL;
x_return_status VARCHAR2 (1) := 'U';
l_msg_index_out NUMBER := 0;
mtl_line_exc EXCEPTION;
l_exception_material_tbl gme_common_pvt.exceptions_tab;
BEGIN
FOR r1 IN c1
LOOP
fnd_global.apps_initialize (user_id => 1114,
resp_id => 23326,
resp_appl_id => 552
);
l_batch_header_rec.batch_id := r1.batch_id;
l_batch_header_rec.actual_cmplt_date:=r1.actual_cmplt_date;
--l_batch_header_rec.batch_close_date:=r1.batch_close_date;
gme_api_pub.complete_batch (p_api_version=> 2.0,
p_validation_level => APPS.GME_COMMON_PVT.G_MAX_ERRORS,
p_init_msg_list => APPS.FND_API.G_TRUE,
p_commit => APPS.FND_API.G_FALSE,
x_message_count => x_message_count,
x_message_list => x_message_list,
x_return_status => x_return_status,
p_batch_header_rec => l_batch_header_rec,
p_org_code => NULL,
P_IGNORE_EXCEPTION => FND_API.G_TRUE,
P_VALIDATE_FLEXFIELDS => FND_API.G_FALSE,
x_batch_header_rec => x_batch_header_rec
,x_exception_material_tbl=>l_exception_material_tbl
);
COMMIT;
DBMS_OUTPUT.put_line (x_return_status);
IF x_return_status = fnd_api.g_ret_sts_success
THEN
COMMIT;
ELSE
IF x_message_count = 1
THEN
RAISE mtl_line_exc;
ELSE
FOR j IN 1 .. x_message_count
LOOP
fnd_msg_pub.get (p_msg_index => j,
p_encoded => 'F',
p_data => x_message_list,
p_msg_index_out => l_msg_index_out
);
RAISE mtl_line_exc;
DBMS_OUTPUT.put_line (x_message_list);
END LOOP;
END IF;
END IF;
END LOOP;
EXCEPTION
WHEN OTHERS
THEN
DBMS_OUTPUT.put_line (x_return_status);
DBMS_OUTPUT.put_line (x_message_list);
END;
No comments:
Post a Comment