ABAP Draft handling 在 SAP 现代 Fiori 应用中的重要作用

发布时间 2023-12-02 17:55:32作者: JerryWang_汪子熙

在SAP ABAP开发中,"Draft handling"(草稿处理)是指一种处理业务对象的机制,使用户能够在事务过程中保存未提交的更改,以便随时回到之前的状态或者在适当的时候提交更改。这个机制的实现允许用户在长时间的事务中保存中间状态,而不必担心数据的不一致性或者丢失。

"Draft handling" 的核心思想是将用户的更改保存为草稿(Draft),这样用户就可以在事务处理的过程中暂时保存工作,而不必立即提交。这对于那些需要长时间完成的事务,或者在用户需要在多个步骤中逐渐构建完整数据集的情况下非常有用。在实际应用中,例如在创建采购订单、销售订单等业务对象时,用户可以在多个步骤中逐渐填充相关信息,而不必一次性完成。

在ABAP中,Draft handling的实现通常涉及使用"BOPF"(Business Object Processing Framework)框架。BOPF是一个SAP提供的框架,用于简化业务对象的创建、更新和删除等操作,同时提供了一些高级特性,如Draft handling。以下是关于Draft handling在ABAP中的一般性步骤和一些示例:

1. 定义业务对象: 在ABAP中,首先需要定义业务对象,这可以通过使用BOPF框架的工具来完成。业务对象定义了数据结构、行为和业务逻辑,同时也指定了是否支持Draft handling。

`DATA: lo_bopf TYPE REF TO cl_bopf_factory.
lo_bopf = cl_bopf_factory=>get_instance( ).
lo_bopf->create_object_type(
  iv_object_type_id    = 'SalesOrder'
  iv_object_type_label = 'Sales Order'
  iv_interface_name    = 'IF_SALESORDER'
).

2. 启用Draft handling: 在业务对象的定义中,需要启用Draft handling的支持。这包括在业务对象类型的定义中设置相应的属性。

`DATA: lo_bopf TYPE REF TO if_bopf_frw_factory,
      lo_object_type TYPE REF TO if_bopf_frw_object_type.

lo_bopf = cl_bopf_frw_factory=>get_instance( ).
lo_object_type = lo_bopf->get_object_type( 'SalesOrder' ).
lo_object_type->set_draft_enabled( abap_true ).

3. 创建草稿: 用户在事务处理中填充数据时,可以选择保存数据为草稿而不提交。这可以通过BOPF框架提供的方法来完成。

`DATA(lo_salesorder) = lo_bopf->create_instance( 'SalesOrder' ).

" 设置数据
lo_salesorder->set_property( 'Customer', '123' ).
lo_salesorder->set_property( 'Product', 'XYZ' ).

" 保存为草稿
lo_salesorder->save( iv_mode = 'D' ).

4. 提交草稿: 当用户决定提交草稿时,可以使用BOPF框架提供的方法提交草稿。

`lo_salesorder->save( iv_mode = 'A' ).

5. 恢复草稿: 如果用户希望恢复到之前的草稿状态,也可以使用BOPF框架提供的方法。

`lo_salesorder->reset( ).

这里提供了一个简单的示例,实际上,Draft handling可能涉及到更多的业务逻辑和复杂的数据关系。通过BOPF框架,ABAP开发者可以更轻松地实现Draft handling,提供更好的用户体验和更灵活的事务处理机制。

总体而言,ABAP中的Draft handling是一种强大的机制,为用户提供了更加灵活和可控的事务处理体验。通过允许用户在事务过程中保存中间状态,而不必立即提交,Draft handling提高了系统的用户友好性,同时保障了数据的一致性和完整性。