点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)专家,我试图了解CRM_ORDE...
点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)专家,我试图了解CRM_ORDE...
加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)
专家,我试图了解CRM_ORDER_MAINTAIN的主要逻辑。
对于我来说,我需要更新 crmd_orderadm_i 和 crmd_customer_h。
这是我的参考链接::链接
这是我的代码块。
包含crm_object_names_con。 数据: lt_orderadm_i TYPE crmt_orderadm_i_comt, ls_orderadm_i TYPE crmt_orderadm_i_com, lt_customer_h TYPE crmt_customer_h_comt, ls_customer_h TYPE crmt_customer_h_com, *其他重要事项 lt_input_fields TYPE crmt_input_field_tab, ls_input_fields TYPE crmt_input_field, lt_nametab TYPE crmt_input_field_names_tab, ls_nametab TYPE crmt_input_field_names, lt_save_guid TYPE crmt_object_guid_tab, ls_save_guid TYPE crmt_object_guid, lt_saved_objects TYPE crmt_return_objects, ls_saved_objects类型crmt_return_objects_struc, lv_lin TYPE i, lv_order_object_id TYPE crmt_object_id, lv_order_object_guid TYPE crmt_object_guid32, lt_exception TYPE crmt_exception_t。 *更新ORDERADM_I *********************************** 清除:ls_nametab,lt_nametab [],ls_input_fields。 ls_orderadm_i-ordered_prod ='已更新'。 ls_nametab ='ORDERED_PROD'。 附加ls_nametab到lt_nametab。 ****************************************************** ************************************** *第一个错误发生在下面的描述中,附加ls_nametab,当我对其进行注释时,会发生另一个错误。 ******************************************* * ls_orderadm_i-description ='已更新'。 * ls_nametab ='DESCRIPTION'。 * APPEND ls_nametab至lt_nametab。 ls_orderadm_i-subst_reason ='更新'。 ls_nametab ='SUBST_REASON'。 附加ls_nametab到lt_nametab。 ls_orderadm_i-header ='DFCA012BA36C85F195C578E7D1DF19EC'。 附加ls_orderadm_i至lt_orderadm_i。 ls_input_fields-ref_kind ='A'。 ls_input_fields-ref_guid ='DFCA012BA36C85F195C578E7D1DF19EC'。 ls_input_fields-objectname ='ORDERADM_I'。 ls_input_fields-field_names [] = lt_nametab []。 将ls_input_fields插入表lt_input_fields中。 ****************************************************** *********** *更新COSTUMER_H 清除:ls_nametab,lt_nametab [],ls_input_fields。 ls_customer_h-zzafld00000p ='更新'。 ls_nametab ='ZZAFLD00000P'。 附加ls_nametab到lt_nametab。 ls_customer_h-zzafld00000q ='更新'。 ls_nametab ='ZZAFLD00000Q'。 附加ls_nametab到lt_nametab。 ls_customer_h-ref_guid ='DFCA012BA36C85F195C578E7D1DF19EC'。 APPEND ls_customer_h至lt_customer_h。 ls_input_fields-ref_kind ='A'。 ls_input_fields-ref_guid ='DFCA012BA36C85F195C578E7D1DF19EC'。 ls_input_fields-objectname ='CUSTOMER_H'。 ls_input_fields-field_names [] = lt_nametab []。 将ls_input_fields插入表lt_input_fields中。 ****************************************************** ******************** 通话功能'CRM_ORDER_MAINTAIN' 出口 it_customer_h = lt_customer_h 输入 et_exception = lt_exception 改变 ct_orderadm_i = lt_orderadm_i 例外情况 error_occurred = 1 document_locked = 2 no_change_allowed = 3 no_authority = 4 其他= 5。 案例sy-subrc。 何时0。 * ls_save_guid = iv_guid。 附录ls_save_guid至lt_save_guid。 结束。 通话功能'CRM_ORDER_SAVE' 出口 it_objects_to_save = lt_save_guid 输入 et_saved_objects = lt_saved_objects 例外情况 document_not_saved = 1 其他= 2。 案例sy-subrc。 当为" 0"时。 清除lv_lin。 描述表lt_saved_objects线lv_lin。 如果lv_lin = 1。 读取表lt_saved_objects INTO ls_saved_objects索引1。 lv_order_object_guid = ls_saved_objects-guid。 lv_order_object_id = ls_saved_objects-object_id。 * 5.调用该函数以提交对CRM的更改。 调用功能" BAPI_TRANSACTION_COMMIT"。 万一。 结束。
我想念什么? 我找不到关于此的任何官方文件。
亲切的问候。
1。 第一次错误
在已排序的密钥表上使用APPEND永远不是一个好主意,除非您确定要按密钥顺序对APPEND进行排序。 几乎所有CRM_ORDER *的表类型都是基于具有唯一键的TYPE SORTED TABLE。
几乎总是使用INSERT ... INTO TABLE!
在您的情况下,由于您尝试执行操作的顺序,您会收到错误消息(将其很好地发布以供将来参考) 附录,我想您的下一个错误也是由于这个原因。请尝试更具体地说明实际发生的错误。在大多数情况下,社区甚至可以通过错误消息为您提供帮助,而无需了解特定的FM。/p>
这是为什么您会遇到第一个错误的原因:
>>短文本:在排序表中插入或更改时出现错误
>>错误分析:将插入一行 或在已排序的位置1更改 内部表(类型为SORTED_TABLE) " \ PROGRAM = ... \ DATA = LT_NAMETAB"。 这样,排序顺序(由表键确定)为
侧面说明:因此,我还建议始终使用INSERT ... INTO TABLE ...而不是APPEND ... TO ....,这样,插入是基于 表格类型(如果不是排序键类型,它也将其"附加"为最后一项)。
例如,如果要指出一点,则必须使用APPEND作为最后一项(如果不受表类型的限制,则必须"插入"作为最后一项)。
2。 第二个错误
由于您不熟悉CRM_ORDER * FM,因此我强烈建议您,因为您在编码过程中会进一步陷入困境,并且如果您真的想知道CRM_ORDER_MAINTAIN的工作原理,请使用Trx。 CRMD_ORDER,更改您想更改的内容,然后调试CRM_ORDER _ *** FM。
在第二个错误的情况下,您尝试更新头寸,但使用标头ref_type和标头guid :
请张贴您收到的错误,以便我们为您提供帮助。
一周热门 更多>