ABAP 泛型编程实战 - 分享一个数据库表内容的拷贝工具试读版

简介: ABAP 泛型编程实战 - 分享一个数据库表内容的拷贝工具试读版

ABAP 泛型编程技术,在本教程之前的多篇文章已经有所介绍:

笔者在实际工作中,经常需要对一些 SAP 系统标准的数据库表进行一些调研工作,比如调整数据库表的字段,或者对这张标准数据库表的内容,进行增删改查等等。

因为是调研性质,自己也没有 100% 把握,所以我一般习惯先将标准的数据库表,拷贝出来成为一个 Z 表。比如下面这张 SAP CRM 系统里标准的数据库表 ZCRMC_OBJECTS:

使用 SE11 事务码里提供的拷贝功能:

在表名字前添加 Z 即可:

下面是拷贝出来的 Z 表,数据结构同原来标准的表一模一样:

然而这只是数据库表的结构做了拷贝,不包含数据库里存放的记录。为此我开发了一个小工具,利用了 ABAP 泛型编程技术,只需要在工具输入参数里,指定源数据库表,和目标数据库表这两张表的名称,工具就能自动将源数据库表的全部内容,拷贝到目标数据库表去。

当然,既然是泛型编程,我的工具源代码里,就没有硬编码任何关于 CRMC_OBJECTS 或者 ZCRMC_OBJECTS 这两张数据库表的结构信息。

所谓 ABAP 泛型编程,主要通过泛型数据类型 来实现,而泛型数据类型的实现,离不开 ABAP 的 Field Symbol.

泛型数据类型允许我们在声明变量、类或接口时不指定具体的数据类型,而是使用类型为 ANY 或者 TABLE 的 Field Symbol 来表示。这些 Field Symbol 在应用程序执行时,才能确定其具体的数据类型。

听起来可能有些抽象,不过不要紧,我们通过具体的例子来实战。

执行笔者开发的数据库表内容拷贝工具(完整源代码在文末),指定两个参数:

  • 源数据库表名:维护想要将其内容复制出来的数据库表名称,在我的使用场景里,通常是 SAP 标准数据库表名称。
  • 目标数据库表名:从 SAP 标准数据库表拷贝出来的 Z 表的名称。

执行完毕后,打印出成功拷贝的数据库表记录数:

下面是详细的源代码讲解。

相关文章
|
4天前
|
前端开发 数据库 开发者
如何在 SEGW 事务码里为 SAP ABAP OData 服务实现 Function Import 试读版
如何在 SEGW 事务码里为 SAP ABAP OData 服务实现 Function Import 试读版
6 1
|
4天前
|
BI 网络安全
如何使用 ABAPGit 在 SAP ABAP 系统安装 abap2xlsx 工具试读版
如何使用 ABAPGit 在 SAP ABAP 系统安装 abap2xlsx 工具试读版
7 0
|
4天前
|
XML 网络安全 开发工具
如何下载并安装 SAP ABAPGit,并完成 ABAP 服务器上 SSL 证书的配置试读版
如何下载并安装 SAP ABAPGit,并完成 ABAP 服务器上 SSL 证书的配置试读版
11 0
|
4天前
|
开发者 UED
ABAP Dynpro 编程里 groups 字段的作用介绍
ABAP Dynpro 编程里 groups 字段的作用介绍
6 0
|
4天前
|
网络安全
实战分析 - 为什么有些 SAP ABAP 程序,启动之后界面有些按钮是灰色的试读版
实战分析 - 为什么有些 SAP ABAP 程序,启动之后界面有些按钮是灰色的试读版
8 0
|
4天前
|
存储 UED 开发者
ABAP Dynpro 编程里 PBO 中 LOOP AT SCREEN 的使用方法介绍
ABAP Dynpro 编程里 PBO 中 LOOP AT SCREEN 的使用方法介绍
8 1
|
4天前
|
存储 Java 分布式数据库
【分布式计算框架】HBase数据库编程实践
【分布式计算框架】HBase数据库编程实践
13 1
|
4天前
|
SQL 数据库
数据库SQL语言实战(六)
本次实战的重点就在于对表格本身的一些处理,包括复制表格、修改表格结构、修改表格数据
|
4天前
|
SQL Oracle 关系型数据库
数据库SQL语言实战(五)(数据库系统概念第三章练习题)
本文的SQL语言适用的是Oracle数据库与mySQL可能存在略微不同
|
4天前
|
SQL Oracle 关系型数据库
数据库SQL语言实战(四)(数据库系统概念第三章练习题)
本文的SQL语言适用的是Oracle数据库与mySQL可能存在略微不同
数据库SQL语言实战(四)(数据库系统概念第三章练习题)
http://www.vxiaotou.com