1)SE11创建自建表,结构如下:

2) 创建表维护

3) 针对上面创建的函数组ZMM_MAT_DESC,做以下增强处理

添加的Module 代码如下:

module mod_customize input.

"自动带出值

zmm_mat_desc-lname = sy-uname.

zmm_mat_desc-ldate = sy-datum.

zmm_mat_desc-ltime = sy-uzeit.

endmodule.                 " MOD_CUSTOMIZE  INPUT

并修改100屏幕,把对应的三个字段设置为不可输入:

4) 创建程序,定义好选择界面,并通过标准函数:VIEW_MAINTENANCE_CALL 调用上面创建的SM30表维护

report  zmm_mat_desc no standard page heading.
 
data: gs_zmm_mat_desc like zmm_mat_desc,
      gt_zmm_mat_desc like table of gs_zmm_mat_desc,
 
      gs_vimsellist like vimsellist,
      gt_vimsellist like table of gs_vimsellist.
 
tables zmm_mat_desc.
select-options:
    s_matnr for zmm_mat_desc-matnr,
    s_maktx for zmm_mat_desc-maktx no intervals,
    s_lname for zmm_mat_desc-lname no intervals,
    s_ldate for zmm_mat_desc-ldate,
    s_ltime for zmm_mat_desc-ltime.
 
select * into table gt_zmm_mat_desc
    from zmm_mat_desc
    where matnr in s_matnr
    and maktx in s_maktx
    and lname in s_lname
    and ltime in s_ltime.
 
loop at  gt_zmm_mat_desc into gs_zmm_mat_desc.
  gs_vimsellist-viewfield  = 'MATNR'.
  gs_vimsellist-operator   = 'EQ'.
  gs_vimsellist-value    = gs_zmm_mat_desc-matnr.
  gs_vimsellist-and_or    = 'OR'.
  append gs_vimsellist to gt_vimsellist.
endloop.
 
call function 'VIEW_MAINTENANCE_CALL'
  exporting
  
 action                       = 'U'
  
 view_name                    = 'ZMM_MAT_DESC'
  tables
  
 dba_sellist                  = gt_vimsellist
  exceptions
  
 client_reference             = 1
  
 foreign_lock                 = 2
    invalid_action               = 3
  
 no_clientindependent_auth    = 4
  
 no_database_function         = 5
  
 no_editor_function           = 6
  
 no_show_auth                 = 7
  
 no_tvdir_entry               = 8
  
 no_upd_auth                  = 9
    only_show_allowed            = 10
  
 system_failure               = 11
    unknown_field_in_dba_sellist = 12
  
 view_not_found               = 13
  
 maintenance_prohibited       = 14
    others                       = 15.
if sy-subrc <> 0.
  message id sy-msgid type sy-msgty number sy-msgno
          with sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
endif

5) 运行程序,效果如下

但是新增时报错:

这是因为指定了选择条件后,添加条目时还要去验证物料是否满足选择条件,显然不符合逻辑;

通过调试发现,需要在上面的Module里面清空掉选择条件限制的标识位,如下:

module mod_customize input.

"清空条件选择的标识位
  clear x_header-selection.
 
  "自动带出值
  zmm_mat_desc-lname = sy-uname.
  zmm_mat_desc-ldate = sy-datum.
  zmm_mat_desc-ltime = sy-uzeit.
 
endmodule.                 " MOD_CUSTOMIZE  INPUT

然后再做新增时,就可以通过了:

SM30 表格维护生成器的更多相关文章

  1. abap 开发之创建表维护生成器

    在sap开发中有时需要对一些自建表维护数据,但又不想写程序,怎么办呢??这个时候我们可以直接生成个表维护生成器,为其定义一个事物码就ok了.以下是表格维护生成器的生成步骤. 首先我们需要先定义表.输入 ...

  2. 【ABAP系列】SAP ABAP 为表维护生成器创建事务代码

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP 为表维护生成器 ...

  3. sm30表维护做排序

    好吧,之前有人问过,因为代码太少就一直没发...今天给出来吧 众所周知,表维护其实就是个TC,只是表维护是统一的,没有使用通用名内表名什么的,这个就不多说了,来重点: TC的一般排序可以放在:1,PB ...

  4. SM30维护视图添加按钮

    转自http://blog.csdn.net/tsj19881202/article/details/7517232 遇到某需求,要求维护sm30的视图时,能加上排序按钮. 基本参考: http:// ...

  5. SM30维护视图创建【转】

           在SAP中,经常需要自定义数据库表.而且可能需要人工维护数据库表中的数据,可以通过SM30进行维护数据:但是SM30事务的权限太大,不适宜将SM30直接分配:因此,可以通过给维护表分配事 ...

  6. SAP技术相关Tcode

    ABAP的常用tcode 开发----------------------------------------------- SE51  屏幕制作 SE91  MESSAGE OBJECT SE80  ...

  7. SE11

        自省数据及表存储 2014年4月6日 21:37     类似JAVA反射的特性 SAP提供自省数据的机制 这样可以保证程序的灵活性和动态性     1.使用OO中的cl_abap_typed ...

  8. ABAP常用事务码

    开发----------------------------------------------- SE51  屏幕制作 SE91  MESSAGE OBJECT SE80  对象浏览器(可以建开发类 ...

  9. 调用SM30数据表维护的函数

    相关文章:http://www.cnblogs.com/caizjian/p/3248499.html 1.se11进去新建一个数据表 2.se55进去生产表维护 3.sm30进去维护数据表 4.se ...

随机推荐

  1. iOS 通用button 上图下字

    UIButton *first = [[UIButton alloc] initWithFrame:CGRectMake(0, 0, kHeight(80), kHeight(80))]; [firs ...

  2. Transform.eulerAngles 欧拉角

    var eulerAngles : Vector3 Description描述 The rotation as Euler angles in degrees. 旋转作为欧拉角度. The x, y, ...

  3. ACM-百度之星资格赛之Labyrinth——hdu4826

    Labyrinth Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  4. 【VBA】设置Excle最近使用文件清单数量

    打开Excle,点击"文件"------"最近使用的文件",如下图: 根据上图可以看到,最近使用的文件数目为11个,那么是怎么实现的呢?具体代码如下: Publ ...

  5. 基于JWT的Token开发案例

    代码地址如下:http://www.demodashi.com/demo/12531.html 0.准备工作 0-1运行环境 jdk1.8 maven 一个能支持以上两者的代码编辑器,作者使用的是ID ...

  6. mfs客户端挂载

    1.安装fuse yum install fuse fuse-devel 2.加载fuse模块 modprobe fuse 3.创建mfs用户 useradd mfs -s /sbin/nologin ...

  7. maven初始搭建一个基础项目(spring mvc+spring+jdbc mysql+jstl)

    技术选型: 一.项目搭建: 1)创建maven项目 (我博客里面有介绍) 选择aptach的maven-archetype-webapp 填入groupIDhe artifactId等 确认项目名称 ...

  8. poj 2553 The Bottom of a Graph(强连通、缩点、出入度)

    题意:给出一个有向图G,寻找所有的sink点.“sink”的定义为:{v∈V|∀w∈V:(v→w)⇒(w→v)},对于一个点v,所有能到达的所有节点w,都能够回到v,这样的点v称为sink. 分析:由 ...

  9. POI 实现合并单元格以及列自适应宽度

    POI是apache提供的一个读写Excel文档的开源组件,在操作excel时常要合并单元格,合并单元格的方法是: sheet.addMergedRegion(new CellRangeAddress ...

  10. k8s部署dns

    硬件环境: 两台虚拟机, 10.10.20.203 部署docker.etcd.flannel.kube-apiserver.kube-controller-manager.kube-schedule ...