ABAP动态生成经典应用之Dynamic SQL Excute 程序

【转自http://blog.csdn.net/mysingle/article/details/678598】
开发说明:在SAP的系统维护过程中,有时我们需要修改一些Table中的数据,可是很多Table又不能直接在Tcode:SE16中修改,使用的SAP ID又没有调试数据修改权限,这时我们应该怎么样修改数据呢?思路--> ABAP程序中的SQL 更新语句谁都有权限执行,只要我们能动态生成修改该Table字段的ABAP CODE动态执行即可!

开发技术:

1.SQL代码编写技术

1.动态程序代码生成技术

2.ABAP动态程序执行技术

注意事项:

SQL语法一定要准确,修改条件准确,修改数据后不违法数据唯一性原则

程序代码:如下

*******************************************************************
* (Copyright @2006 Mysingle Digital System Co.Ltd.
* All Rights Reserved|Confidential)
* System Module   :  ABAP CBO
* Program Description  :  Dynamic SQL Excute
* Developer         :  ZOU XIN
* Develop Date   :  2006.03.01
* Use Status   :  Release 1.0
*******************************************************************
REPORT z_cbo_abap_02 MESSAGE-ID zp NO STANDARD PAGE HEADING.

DATA : fcode LIKE sy-ucomm,
       changed LIKE s38e-buf_varied,
       save_tabix  LIKE sy-tabix,
       tabix_count TYPE i,
       select_key(10) TYPE c,
       etc(80)  TYPE c,
       update_flag  TYPE c,
       line_cnt     TYPE i,
       prog(8)      TYPE c,
       msg(120)     TYPE c,
       msg_text(72) TYPE c,
       confirm_flag TYPE c.

DATA: itab_sql LIKE abapsource OCCURS 0 WITH HEADER LINE,
      itab_prog LIKE abapsource OCCURS 0 WITH HEADER LINE.

START-OF-SELECTION.

*程序执行直接进入ABAP代码编辑器
  SET PF-STATUS ‘PFSTA00‘.
  WRITE: /1 ‘Edit Your SQL ................‘ COLOR 2.

AT USER-COMMAND.

*动态生成程序修改确认
  IF sy-ucomm = ‘EDIT‘.
    PERFORM editor_sql.

*动态生成程序执行

ELSEIF sy-ucomm = ‘EXEC‘ OR sy-ucomm = ‘EDEX‘.
    REFRESH itab_prog.
    CLEAR itab_prog.
    IF update_flag = ‘X‘.
      PERFORM exec_modify.
    ENDIF.
  ENDIF.

*&------------------------------------------------------------------*
*&      Form  editor_sql
*&------------------------------------------------------------------*
FORM editor_sql.
* CALL Editor
  CALL FUNCTION ‘EDITOR_APPLICATION‘
       EXPORTING
            application = ‘BF‘
            display     = ‘ ‘
            name        = ‘[Edit Your SQL......]‘
       IMPORTING
            fcode       = fcode
            changed     = changed
       TABLES
            content     = itab_sql.
* Translate Code Upper
  LOOP AT itab_sql.
    save_tabix  = sy-tabix.
    tabix_count = tabix_count + 1.
    IF itab_sql-line = space OR itab_sql-line+(1) = ‘*‘.
      DELETE itab_sql INDEX save_tabix.
    ENDIF.
    TRANSLATE itab_sql-line TO UPPER CASE.
    MODIFY itab_sql INDEX save_tabix.
  ENDLOOP.

* Parsing input SQL code
  LOOP AT itab_sql.
    IF sy-tabix = 1.
      SHIFT itab_sql-line LEFT DELETING LEADING space.
    ENDIF.
    save_tabix = sy-tabix + 1.
    SPLIT itab_sql-line AT space INTO select_key etc.
    IF select_key = ‘SELECT‘.
      MESSAGE i433 WITH ‘Donot support select syntax!^~^‘.
      stop.
* hehe~~Don‘t bother myself.
    ELSEIF select_key = ‘DELETE‘ OR  select_key = ‘UPDATE‘
       OR  select_key = ‘INSERT‘.
      update_flag = ‘X‘.
    ENDIF.
  ENDLOOP.

* Display the SQL code
  sy-lsind = 0.
  DELETE itab_sql WHERE line IS initial.
  DESCRIBE TABLE itab_sql LINES line_cnt.
  IF line_cnt = 0.
    WRITE: /1 ‘Edit Your SQL ................‘ COLOR 2.
  ELSE.
    LOOP AT itab_sql.
      WRITE: /1 itab_sql-line.
    ENDLOOP.
  ENDIF.
  IF update_flag = ‘Y‘.
    EXIT.
  ENDIF.
ENDFORM.                    " editor_sql
*&------------------------------------------------------------------*
*&      Form  exec_modify
*&------------------------------------------------------------------*
FORM exec_modify.
  IF sy-ucomm = ‘EXEC‘.
* Modify dialog box
    CALL FUNCTION ‘POPUP_TO_CONFIRM_STEP‘
         EXPORTING
              textline1 = ‘Do you want to really UPDATE?‘
              titel     = ‘Exit‘
         IMPORTING
              answer    = confirm_flag.
    CASE confirm_flag.
      WHEN ‘N‘. EXIT. "NO
      WHEN ‘A‘. EXIT. "Cancel
      WHEN ‘J‘. "perform exec_sql_update. "YES
    ENDCASE.
  ENDIF.
* Modify Program ABAP Code.
  itab_prog-line = ‘PROGRAM ZSQL19800526 MESSAGE-ID AT.‘.
  APPEND itab_prog.
  itab_prog-line = ‘DATA: COUNT TYPE I.‘.
  APPEND itab_prog.
  itab_prog-line = ‘FORM DYN2.‘.
  APPEND itab_prog.
  itab_prog-line = ‘EXEC SQL.‘.
  APPEND itab_prog.
  LOOP AT itab_sql.
    itab_prog-line = itab_sql-line.
    APPEND itab_prog.
  ENDLOOP.
  itab_prog-line = ‘ENDEXEC.‘.
  APPEND itab_prog.
  itab_prog-line = ‘MESSAGE I315 WITH ‘‘Performed‘‘ SY-DBCNT‘.
  CONCATENATE itab_prog-line ‘‘‘‘ ‘Records!^-^‘ ‘‘‘‘ ‘.‘
              INTO itab_prog-line SEPARATED BY space.
  APPEND itab_prog.
  itab_prog-line = ‘ENDFORM.‘.
  APPEND itab_prog.

* Dynamic Program Display
  IF sy-ucomm = ‘EDEX‘.
    CALL FUNCTION ‘EDITOR_APPLICATION‘
         EXPORTING
              application = ‘BF‘
              display     = ‘ ‘
              name        = ‘Modify Program...‘
         IMPORTING
              fcode       = fcode
         TABLES
              content     = itab_prog.
    STOP.
  ENDIF.

* Dynamic Program Excuted
  GENERATE SUBROUTINE POOL itab_prog NAME prog
                                     MESSAGE msg.
  IF sy-subrc <> 0.
    msg_text = msg+(80).
    WRITE: /1 msg_text.
    msg_text = msg+80(40).
    WRITE: /1 msg_text.
  ELSE.
    PERFORM dyn2 IN PROGRAM (prog).
  ENDIF.
ENDFORM.                    " exec_modify

程序实例:

1.程序执行界面,显示SQL CODE录入画面

2.我们要修改的数据,材料主数据Material Master Table:MARA中的材料CODE主键

SOH-DL3C ---> SOH-DL8C

3.数据修改SQL语句编写,这里就不详叙了

UPDATE MARA SET MATNR = ‘SOH-DL3C‘ WHERE MATNR = ‘SOH-DL8C‘
                                    AND ERSDA = ‘20040310‘

4.修改动态ABAP程序生成确认修改

5.动态程序执行

6.程序成功执行提示信息

7.数据修改效果确认

OK!Thank you~

时间: 2024-08-13 07:01:49

ABAP动态生成经典应用之Dynamic SQL Excute 程序的相关文章

ABAP 动态生成内表的几种方法

最近要写个程序,既有更新的,也有删除的,需要涉及到很多系统表,如果一个表一个表进行更新或者删除太慢了,于是就想通过创建动态内表来实现这些功能,在网上找了一些资料,经过多次尝试,终于测试成功了.网上讲述的创建动态内表的方法大致有两种.我做了一下测试,源代码附后.在这里提醒大家一点,在做动态更新程序的时候,要注意两点:      1.使用modify (p_tabname) from <dyn_wa>. 的时候,一定要确定要更新的字段是不是系统表的关键字段,如果是关键字段的话,需要先删除这条记录,

WPF 动态生成对象属性 (dynamic)

原文:WPF 动态生成对象属性 (dynamic) 项目中列行的数据 都需要动态生成 所以考虑到对象绑定  可需要一个动态生成属性的意思 缺点 加载速度会慢 很明显的慢 解决办法 尽量减轻动态属性的量~ 参考文章 https://www.cnblogs.com/maomiyouai/p/3594132.html https://www.cnblogs.com/dingli/archive/2012/06/14/2548687.html(这个没看明白 但是冥冥中让我觉得 收藏一下以后可能会用) 代

WPF Datagrid 动态生成列 并绑定数据

原文:WPF Datagrid 动态生成列 并绑定数据 说的是这里 因为列头是动态加载的 (后台for循环 一会能看到代码) 数据来源于左侧列 左侧列数据源 当然num1 属于临时的dome使用  可以用ObservableCollection集合代表 动态创建属性 WPF 动态生成对象属性 (dynamic) ObservableCollection<NameList> listName = new ObservableCollection<NameList>(); privat

动态生成ABAP程序-资料

参考程序: Tcode ABAPdocu--> BC - ABAP Programming--> The ABAP Programming Language--> Special Techniques--> Generating Programs Dynamically. 1.仅动态生成程序代码: REPORT demo_special_tech_dyn_insert. DATA: code TYPE TABLE OF rssource-line. * type of an edi

mybatis使用注解替代xml配置,动态生成Sql

mybatis使用注解替代xml配置时,遇到判断条件是否为null或者为空时,@Select很难搞定,不知道怎么办? mybatis3中增加了使用注解来配置Mapper的新特性,使用 SelectProvider来动态生成sql. 典型的使用场景 1. 无参数@SelectProvide方法在Mapper接口方法上和@SelectProvide指定类方法上,均无参数:UserMapper.java: 1     @SelectProvider(type = SqlProvider.class, 

模拟Hibernate动态生成SQL语句

这里有一个xml配置文件,也就是Hibernate框架中会用到的POJO和数据库的映射文件 1 <?xml version="1.0" encoding="utf-8"?> 2 <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 3 "http://www.hibernate.org/dtd/hibernate-

自定义ORMapping—动态生成SQL语句

概述 之前在自定义ORMapping--关系表转换为实体或实体集合对象中提到过ORMapping的东西,在那片博客中也有ORMapping实现的一个简单思路,当时只实现了关系表转换为实体或实体集合这个功能,没有实现动态生成SQL这个部分,本片博客就是完善之前的那片博客,实现动态生成SQL语句这么一个功能. 实现思路 1.创建两个自定义特性,分别为表特性和字段特性,目的就是给相应的实体类的类名和属性名,打上相应的特性,从而创建类名和表名,属性和表字段名之间的对应关系 2.创建一个特性解析类,用来解

即使用ADO.NET,也要轻量级动态生成更新SQL

不管出于什么原因,有时候框架人员摒弃了NH或EF,而使用原生数据库访问对象. 为了优美的编程,用上我写的轻量级动态生成更新SQL扩展方法吧 还记得在EF中只更新修改过的字段时,我们这么写: var e = db.Entry(d); e.State = EntityState.Unchanged; d.UploadTime = DateTime.Now; e.Property("UploadTime").IsModified = true; db.SaveChanges(); 目的是,使

ABAP根据输入的表名动态生成上传TXT数据的代码

开发技术: 1.文本文件上载技术 2.动态程序代码生成技术 3.ABAP动态程序执行技术 4.TXT文本文件对应用Table字段编辑技术 注意事项: 文件文件编辑过程中时间日期格式为 20060201 120000 表示 2006.02.01 12:00:00 文本文件中不能包含除字符,数字之外的其他特殊符号.假如Table中对应的字段数据为空时,在编辑数据时也对应该列为空. 程序代码:如下 *&--------------------------------------------------