*下面的代码是在alv字段中修改字段的内容,点击保存后就可以保存数据至数据表。

TABLES: spfli.

DATA:

wa_fieldcat TYPE lvc_s_fcat ,  " 相当于工作区

i_fieldcat  TYPE lvc_t_fcat ,  " 存放输出栏位名称的列表

i_layout    TYPE lvc_s_layo .  " 负责整个ALV的全局属性

DATA tab_spfli LIKE  TABLE OF spfli WITH HEADER LINE.  " 定义内表
 DATA wa_spfli TYPE spfli.

DATA it_spfli LIKE STANDARD TABLE OF spfli.   " 定义内表
 DATA lt_spfli TYPE spfli.

SELECT * FROM spfli
   INTO CORRESPONDING FIELDS OF TABLE tab_spfli.  "将数据表中的数据存入内表中

PERFORM getfield.
PERFORM is_layout.
DATA: l_user_command TYPE slis_formname VALUE 'USER_COMMAND'.  "定义返回事件
CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY_LVC'     "定义显示内表
  EXPORTING
    I_CALLBACK_PROGRAM                = sy-repid
    I_CALLBACK_USER_COMMAND           = l_user_command
    IS_LAYOUT_LVC                     = i_layout
    IT_FIELDCAT_LVC                   = i_fieldcat
    I_SAVE                            = 'A'
  TABLES
    t_outtab                          = tab_spfli
  EXCEPTIONS
    PROGRAM_ERROR                     = 1
    OTHERS                            = 2
          .
IF sy-subrc <> 0.
* Implement suitable error handling here
ENDIF.

FORM getfield.     "定义显示字段  
    wa_fieldcat-col_pos   = 1 .
    wa_fieldcat-fieldname = 'CARRID'.
    wa_fieldcat-just      = 'C'.
    wa_fieldcat-seltext = '航线代码'.
    wa_fieldcat-fix_column = 'X'.
    APPEND wa_fieldcat TO i_fieldcat.
    CLEAR wa_fieldcat.

wa_fieldcat-col_pos   = 2 .
    wa_fieldcat-fieldname = 'CONNID'.
    wa_fieldcat-just      = 'C'.
    wa_fieldcat-seltext = '航班连接号'.
    wa_fieldcat-fix_column = 'X'.
    APPEND wa_fieldcat TO i_fieldcat.
    CLEAR wa_fieldcat.

wa_fieldcat-col_pos   = 3 .
    wa_fieldcat-fieldname = 'CITYFROM'.
    wa_fieldcat-just      = 'C'.
    wa_fieldcat-seltext = '起飞城市'.
    wa_fieldcat-edit      = 'X'.           "设置成可编辑状态
    APPEND wa_fieldcat TO i_fieldcat.
    CLEAR wa_fieldcat.

wa_fieldcat-col_pos   = 4 .
    wa_fieldcat-fieldname = 'CITYTO'.
    wa_fieldcat-just      = 'C'.
    wa_fieldcat-seltext = '到达城市'.
    wa_fieldcat-edit      = 'X'.           "设置成可编辑状态
    APPEND wa_fieldcat TO i_fieldcat.
    CLEAR wa_fieldcat.

wa_fieldcat-col_pos   = 5 .
    wa_fieldcat-fieldname = 'DERTIME'.
    wa_fieldcat-just      = 'C'.
    wa_fieldcat-seltext = '出发时间'.
    APPEND wa_fieldcat TO i_fieldcat.
    CLEAR wa_fieldcat.

wa_fieldcat-col_pos   = 6 .
    wa_fieldcat-fieldname = 'ARRTIME'.
    wa_fieldcat-just      = 'C'.
    wa_fieldcat-seltext = '到达时间'.
    APPEND wa_fieldcat TO i_fieldcat.
    CLEAR wa_fieldcat.

ENDFORM.

FORM is_layout.     "定义ALV显示样式
   i_layout-ZEBRA = 'X'.
   i_layout-CWIDTH_OPT = 'X'.
ENDFORM.

FORM user_command USING r_ucomm LIKE sy-ucomm               "执行事件
                  rs_selfield TYPE slis_selfield.

CASE r_ucomm .

WHEN '&DATA_SAVE'.                  "当点击保存按钮时执行下面代码

SELECT * FROM spfli INTO TABLE  it_spfli  "tab_spfli 查找数据表中数据到内表 
       FOR ALL ENTRIES IN tab_spfli
       WHERE carrid = tab_spfli-carrid AND connid = tab_spfli-connid.

LOOP AT it_spfli INTO lt_spfli.   "循环内表
            READ TABLE tab_spfli INTO wa_spfli  WITH KEY   "读取修改后的内表
              carrid = lt_spfli-carrid connid = lt_spfli-connid.
            IF sy-subrc = 0.   "如果读取一致将修改后的内表字段的值赋值给新内表字段
              lt_spfli-cityfrom  = wa_spfli-cityfrom.
              lt_spfli-cityto    = wa_spfli-cityto.
              MODIFY it_spfli FROM lt_spfli.  "更新修改后的内表字段的值
            ENDIF.
            CLEAR lt_spfli.
            CLEAR wa_spfli.
          ENDLOOP.
          UPDATE spfli FROM TABLE it_spfli.  "根据更新后的内表更新数据表,将更新后的字段的值传入数据表中。
          IF sy-subrc = 0.
            COMMIT WORK.
*            MESSAGE '保存成功' TYPE 'I'.
            MESSAGE '保存成功' TYPE 'I'.
          ELSE.
            ROLLBACK WORK.
          ENDIF.
        WHEN '2'.
        WHEN OTHERS.

ENDCASE.
ENDFORM.

ABAP分享五 ALV修改单元格并将修改数据更新到数据表中示例1的更多相关文章

  1. ABAP分享二 ALV标准范例DEMO汇总

    SAP软件针对ALV的使用方法,提供了ALV标准demo程序: sap提供的ALV标准demo程序,只是展示简单的数据,用function ALV即可,若有复杂的增删改查操作 建议使用OO ALV,下 ...

  2. Easyui之datagrid实现点击单元格修改单元格背景颜色

    前段时间有个需求中有点击datagrid的单元格实现某种事件,调用datagrid的onclickCell这个方法很容易实现,但是体验不好啊,完全不知道自己刚才点击的是哪个单元格,然后就尝试单击单元格 ...

  3. Excel表格如何保护单元格不被修改

    Excel如何保护单元格不被修改  有时使用Excel时希望保护单元格不被修改,这可以叫做单元格的“写保护”即把光标定位在一个不允许输入数据的区域内时,是无论如何也无法在里面输入数据的.下面咱们就一起 ...

  4. poi操作Excel并修改单元格背景色

    废话不多说,直接来代码!!! 其中标红的才是重点!!! 代码中有时可以不用创建新文件, 如果报错的话可以通过创建新文件来进行操作(懒,没去找报错原因),不过原文件也会被修改. 操作之前做好备份!操作之 ...

  5. 27.openpyxl 向指定单元格添加图片并修改图片大小 以及修改单元格行高列宽

    openpyxl 向指定单元格添加图片并修改图片大小 以及修改单元格行高列宽 from openpyxl import Workbook,load_workbook from openpyxl.dra ...

  6. SQL Server 2008空间数据应用系列五:数据表中使用空间数据类型

    原文:SQL Server 2008空间数据应用系列五:数据表中使用空间数据类型 友情提示,您阅读本篇博文的先决条件如下: 1.本文示例基于Microsoft SQL Server 2008 R2调测 ...

  7. mssql sqlserver 使用sql脚本检测数据表中一列数据是否连续的方法分享

    原文地址:http://www.maomao365.com/?p=7335 摘要:    数据表中,有一列是自动流水号,由于各种操作异常原因(或者插入失败),此列数据会变的不连续,下文将讲述使用sql ...

  8. 使用PreparedStatement向数据表中插入、修改、删除、获取Blob类型的数据

    使用PreparedStatement向数据表中插入.修改.删除.获取Blob类型的数据 2014-09-07 20:17 Blob介绍 BLOB类型的字段用于存储二进制数据 MySQL中,BLOB是 ...

  9. ABAP ALV单个单元格状态编辑

    *&---------------------------------------------------------------------* *& Report  ZPPR0024 ...

随机推荐

  1. Asp.net Core 3.0 Identity 使用smtp账户确认和密码恢复

    当新建一个core项目后,使用identity基架后,确认邮件出现了错误,并不能正常使用. 建立文档在这里 https://docs.microsoft.com/zh-cn/aspnet/core/s ...

  2. openstack网络(一)

    什么是OpenStack Networking OpenStack网络的特性 交换机 路由器 负载均衡 防火墙 虚拟专用网络 网络功能虚拟化 网络类型 管理网络 API 网络 外部网络 访客网络 在一 ...

  3. MyBatis_多表关联查询_resultMap_单个对象_N+1方式实现

    mapper 层 提供 StudentMapper 和 ClazzMapper, StudentMapper 查询所有学生信息, ClazzMapper 根据编号查询班级信息. 再 StudentMa ...

  4. [TimLinux] django 下载功能中文文件名问题

    from django.utils.encoding import escape_uri_pathfrom django.http import HttpResponse def download(r ...

  5. HDU-1754 A - I Hate It

    很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少. 这让很多学生很反感. 不管你喜不喜欢,现在需要你做的是,就是按照老师的要求,写一个程序,模拟老师的询问.当然,老师有 ...

  6. 笔记||Python3之循环

    循环:          循环概念:在一定条件下,重复做某件事情(代码)          while循环:1 - while 条件表达式: 循环体 2 - 当 条件表达式 == True   才执行 ...

  7. 基于 H5 + WebGL 实现 3D 可视化地铁系统

    前言 工业互联网,物联网,可视化等名词在我们现在信息化的大背景下已经是耳熟能详,日常生活的交通,出行,吃穿等可能都可以用信息化的方式来为我们表达,在传统的可视化监控领域,一般都是基于 Web SCAD ...

  8. 跟着文档学习gulp1.2创建任务(task)

    导出任务 任务(task)可以分为公开(public)或私有(private)类型 公开任务从gulpfile中被导出(export),可以通过gulp命令直接调用 私有任务被设计为在内部使用,通常作 ...

  9. 《Java基础知识》Java方法重载和重写

    重写(Override) 重写是子类对父类的允许访问的方法的实现过程进行重新编写, 返回值和形参都不能改变.即外壳不变,核心重写! 重写的好处在于子类可以根据需要,定义特定于自己的行为. 也就是说子类 ...

  10. [ASP.NET Core 3框架揭秘] 文件系统[3]:物理文件系统

    ASP.NET Core应用中使用得最多的还是具体的物理文件,比如配置文件.View文件以及作为Web资源的静态文件.物理文件系统由定义在NuGet包"Microsoft.Extension ...