点击此处---> 群内免费提供SAP练习系统(在群公告中)
加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)
嗨,我似乎无法在进行更改后将修改后的数据保存到数据库表(zekko03)中。 我现在正在保存标题。
示例程序并不像我尝试过的那样真正适用于我的情况。
应该是逻辑问题,可以列出/显示save_database_update子例程应该如何按逻辑顺序工作以及使用什么语法?
数据:G_GRID_LEFT TYPE REF CL_GUI_ALV_GRID, G_GRID_RIGHT类型参考CL_GUI_ALV_GRID, GS_LAYOUT类型LVC_S_LAYO。 执行FIELDCAT。 GS_LAYOUT-EDIT = ABAP_TRUE。 呼叫方法G_GRID_LEFT-> SET_TABLE_FOR_FIRST_DISPLAY 出口 IS_VARIANT = LS_VARIANT I_STRUCTURE_NAME ='ZEKKO03' I_SAVE =保存 IS_LAYOUT = GS_LAYOUT 改变 IT_OUTTAB = GT_ZHEADER IT_FIELDCATALOG = GT_FIELDCAT 例外情况 INVALID_PARAMETER_COMBINATION = 1 PROGRAM_ERROR = 2 TOO_MANY_LINES = 3 其他= 4。 如果SY-SUBRC <> 0。 消息ID SY-MSGID类型SY-MSGTY编号SY-MSGNO 与SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4。 ENDIF。
MODULE USER_COMMAND_0100输入。 调用方法CL_GUI_CFW => DISPATCH。 案例SY-UCOMM。 当"更新"。 执行SAVE_DATABASE_UPDATE。 当"切换"时。 进行SWITCH_EDIT_MODE。 当别人。 结束。 ENDMODULE。
更新方法有效,这意味着记录已更新。 但是,在调用alv程序时,标头zekko03记录不会被更新。
当我调试时,修改过的字段首先会更新(从YNB更改为ZNB)
稍后只需要一条记录(第一条记录),执行完调试模式后,记录就不会更新
FORM SAVE_DATABASE_UPDATE。 将gt_zheader循环到gs_zheader。 呼叫方法ZCL_03_DATA_MODEL => SELECT_PURCHASE_ORDERS 出口 IV_KEY = gs_zheader-ebeln IV_MAX_ROWS = IV_MAX_ROWS 输入 IT_ZHEADER = gt_zheader 。 呼叫方法ZCL_03_DATA_MODEL => UPDATE_PURCHASE_ORDERS 出口 IT_ZHEADER = GT_ZHEADER IT_ZITEMS = GT_ZITEMS 输入 ES_BAPIRET2 = BAPIRET2。 结局。 ENDFORM。
这些是我使用过的一些参考书
http://saptechnical.com/Tutorials/ALV/Edit/demo.htm
https://answers.sap。 com/questions/5294394/problem-with-alv-edit-and-save.html
(64.9 kB)
嗨
对数据库表进行更改后,您是否执行数据库提交?
关于
Mateusz
您是说对G_GRID_LEFT-> GET_SELECTED_ROWS的调用返回空参数ET_INDEX_ROWS和ET_ROW_NO吗?
如果用户未明确选择任何行,则通常为空。 但是,您真的只想保存用户标记的行吗?
此外,我认为您不了解所选行的概念,因为默认情况下GET_SELECTED_ROWS最多可以返回一行,因为您没有 不能设置布局选项SEL_MODE(必须为'A','C'或'D'才能选择几行)。
无论如何,为什么要在循环内更新数据库表? 为什么不一次调用UPDATE_PURCHASE_ORDERS,而内部表包含要更新的行呢?
调用G_GRID_LEFT-> GET_SELECTED_ROWS ET_ROW_NO
实际上我上面的get_selected_row代码用于删除子例程,当切换到不可编辑模式(switch_mode)时,选择一行并删除。
我尝试对update应用相同的操作,以查看所选行的修改后的值是否得到更新
只要表更新即使没有选择的行也可以,问题就在于没有选择的行。 在调试模式下,修改后的记录甚至不会反映出来,也不会执行任何更新。
我想不出其他方式编写代码,否则更新无法反映在视频中
在调试模式下(屏幕截图),内部表中没有反映更新的值
最后的评论不再与原始问题相关,对以后的访问者不再有用。 无论如何,我认为没有人知道这里发生了什么。
您先前的评论是关于GET_SELECTED_ROWS的,而现在您谈论的是删除和未反映的数据,而没有提供关于我的最后评论的反馈。 很难理解您是否做了任何事情,改变了主意,以及您的最新评论是否与我的最新评论有任何关系。
让我们回答您的一个担忧:您说用户输入了 屏幕没有反映出来。 那很正常 您必须调用方法CHECK_CHANGED_DATA才能将输入值传输到内部表中。
最好一次性修改表。 不是按记录记录,而是使用整个IT_ZHEADER表。
注意
Mateusz
一周热门 更多>