CO11N报工使用BAPI_PRODORDCONF_CREATE_TT时无法返回配置错误消息CK466

本文主要是介绍CO11N报工使用BAPI_PRODORDCONF_CREATE_TT时无法返回配置错误消息CK466,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前些天碰到一个问题,CO11N前台报工时,会触发一个配置E类型的消息CK466,但是在调用BAPI_PRODORDCONF_CREATE_TT时,该消息并不会返回,而是返回S类型消息。

错误重现:

1.kp26取消维护变动价格

2.SM30及SE16N将对应的错误消息类型更改为E

 视图:V_TCMF9

 表:TCMFA

 此时前台执行CO11N就会触发CK466的报错,经过代码追踪,发现问题所在:

Form det_conf_cost中,其实会捕获到配置的E类型消息,但是只会当以下三种情况时才会捕获错误消息且终止报工。

1.前台处理时:

2.后台处理时:

 3.当订单类型是网络订单时:

除此以外的情况,都不会打上取消标记并下入下面的错误处理逻辑:

所以问题就在于让BAPI调用时也能够将错误消息收集起来,经过对源码进一步分析,错误最终会返回在内表 t_cost_cmfnr 中,只需要找到合适的增强点,调用上述处理函数CM_F_MESSAGES_GET并触发异常no_costing,即可将配置出来的错误消息返回给BAPI的return参数。

解决方案:重写系统预留增强选项。

ENHANCEMENT 1  ZE_PRODCONF_CATCH_ERR.    "active version
* >>> Operation Account Assignment
* In the case of OLC PM/CS order need to initialize and then free
* a buffer for the order operations in the pmco_op update.
* This is due to performance issues when confirming mass operations
* especially during CAT9 transfer.IF cl_erp_co_olc_tools=>is_olc_relevant( caufvd-netzkont ) = abap_true ANDcaufvd-autyp = auftragstyp-inst.CALL FUNCTION 'PMCO_OPS_BUFFER_INIT'.PERFORM det_conf_cost USING caufvd.CALL FUNCTION 'PMCO_OPS_BUFFER_FREE'.ELSE.PERFORM det_conf_cost USING caufvd.ENDIF.*   Catch cost error for BAPI BAPI_PRODORDCONF_CREATE_TTIF flg_bapi = abap_true.READ TABLE t_cost_cmfnr INTO DATA(ls_cost_cmfnr)WITH KEY msgty = 'E'.IF sy-subrc = 0.ROLLBACK WORK.DATA lt_cmfmsg TYPE STANDARD TABLE OF cmfmsg.MOVE-CORRESPONDING t_cost_cmfnr[] TO lt_cmfmsg.*       Bei Storno Fehlermeldung aus CO anzeigenCALL FUNCTION 'CM_F_MESSAGES_GET'EXPORTINGaplid                  = aplid_ppruTABLESe_msgprot              = lt_cmfmsgEXCEPTIONSnot_active             = 1OTHERS                 = 2.IF sy-subrc IS INITIAL.
*         Erste Fehlermeldung ausgebenREAD TABLE lt_cmfmsg INTO DATA(ls_cmfmsg)WITH KEY msgty = message_type-error.MESSAGE ID ls_cmfmsg-arbgb TYPE message_type-errorNUMBER ls_cmfmsg-msgnr WITH ls_cmfmsg-msgv1ls_cmfmsg-msgv2 ls_cmfmsg-msgv3 ls_cmfmsg-msgv4RAISING no_costing.ENDIF.IF caufvd-autyp NE auftragstyp-netw.MESSAGE a085 WITH caufvd-aufnr RAISING no_costing.ELSE.MESSAGE a087 WITH caufvd-aufnr RAISING no_costing.ENDIF.ENDIF.ENDIF.
* <<< Operation Account Assignment
ENDENHANCEMENT.

 代码测试:

REPORT ztest_13065_co11n.DATA:ls_propose            TYPE bapi_pp_conf_prop,lt_timetickets        TYPE STANDARD TABLE OF bapi_pp_timeticket,ls_timetickets        TYPE bapi_pp_timeticket,lt_goodsmovements     TYPE STANDARD TABLE OF bapi2017_gm_item_create,ls_goodsmovements     TYPE bapi2017_gm_item_create,lt_link_conf_goodsmov TYPE STANDARD TABLE OF bapi_link_conf_goodsmov,lt_return             TYPE STANDARD TABLE OF bapi_coru_return,ls_return             TYPE bapiret1.ls_propose-quantity      = 'X'.
ls_propose-activity      = 'X'.
ls_propose-date_and_time = 'X'.
ls_propose-goodsmovement = 'X'.ls_timetickets-orderid   = '000001001322'.
ls_timetickets-operation = '0010'.
APPEND ls_timetickets TO lt_timetickets.ls_goodsmovements-orderid    = '000001001322'.
ls_goodsmovements-order_itno = '0010'.
APPEND ls_goodsmovements TO lt_goodsmovements.CALL FUNCTION 'BAPI_PRODORDCONF_GET_TT_PROP'EXPORTINGpropose            = ls_proposeIMPORTINGreturn             = ls_returnTABLEStimetickets        = lt_timeticketsgoodsmovements     = lt_goodsmovementslink_conf_goodsmov = lt_link_conf_goodsmov
*   DETAIL_RETURN      =
*   FSH_BUNDLES        =.CALL FUNCTION 'BAPI_PRODORDCONF_CREATE_TT'EXPORTINGpost_wrong_entries    = '2'
*   testrun               = 'X'
*    call_on_inbound_queue = 'A'IMPORTINGreturn                = ls_returnTABLEStimetickets           = lt_timeticketsgoodsmovements        = lt_goodsmovementslink_conf_goodsmov    = lt_link_conf_goodsmov
*   CHARACTERISTICS_WIPBATCH       =
*   LINK_CONF_CHAR_WIPBATCH        =detail_return         = lt_return
*   CHARACTERISTICS_BATCH =
*   LINK_GM_CHAR_BATCH    =.cl_demo_output=>new( )->begin_section( 'ls_return' )->write_data( ls_return)->begin_section( 'lt_return' )->write_data( lt_return)->display( ).

BAPI返回结果:

同理应该可以解决类似情况的相同问题,以上。

这篇关于CO11N报工使用BAPI_PRODORDCONF_CREATE_TT时无法返回配置错误消息CK466的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/312169

相关文章

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

Linux alias的三种使用场景方式

《Linuxalias的三种使用场景方式》文章介绍了Linux中`alias`命令的三种使用场景:临时别名、用户级别别名和系统级别别名,临时别名仅在当前终端有效,用户级别别名在当前用户下所有终端有效... 目录linux alias三种使用场景一次性适用于当前用户全局生效,所有用户都可调用删除总结Linux

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超