如何将ABAP透明表的内容导入PostgreSQL数据库-阿里云开发者社区

开发者社区> 开发者小助手-bz4> 正文

如何将ABAP透明表的内容导入PostgreSQL数据库

简介: 如何将ABAP透明表的内容导入PostgreSQL数据库
+关注继续查看

In my previous blog Replicate ABAP database table definition to PostgreSQL the step how to replicate the table definition in ABAP server into PostgreSQL is introduced. As now we already have empty table, the next step is to replicate the transaction data of that table from ABAP server to PostgreSQL.


Now ABAP table COMM_PRODUCT is successfully replicated to PostgreSQL:


image.pngIn my ABAP server table COMM_PRODUCT has totally 94331 entries:

image.pngExecute the report below:REPORT zexport_data.

DATA: lt_export  TYPE string_table,

     l_filename TYPE string,

     l_path     TYPE string,

     l_fullpath TYPE string,

     lv_from    TYPE string,

     lv_to      TYPE string,

     lt_result  TYPE TABLE OF comm_product.

SELECT * INTO TABLE lt_result FROM comm_product.

LOOP AT lt_result INTO DATA(r).

 PERFORM format_timestamp USING r-valid_from CHANGING lv_from.

 PERFORM format_timestamp USING r-valid_to CHANGING lv_to.

 DATA(lv_line) = |{ r-client };{ r-product_guid };{ r-product_id };{ r-product_type };| &

 |{ r-config };{ r-xnosearch };{ r-object_family };{ r-batch_dedicated };{ r-competitor_prod };| &

 |{ lv_from };{ lv_to };{ r-upname };{ r-histex };{ r-logsys }| .

 APPEND lv_line TO lt_export.

ENDLOOP.

CALL METHOD cl_gui_frontend_services=>file_save_dialog

 EXPORTING

   window_title         = 'Save export data file'

   default_file_name    = 'PostgreSQL.txt'

 CHANGING

   filename             = l_filename

   path                 = l_path

   fullpath             = l_fullpath

 EXCEPTIONS

   cntl_error           = 1

   error_no_gui         = 2

   not_supported_by_gui = 3

   OTHERS               = 4.

IF sy-subrc <> 0.

 WRITE:/ 'file save dialog failed.'.

 RETURN.

ENDIF.

CALL METHOD cl_gui_frontend_services=>gui_download

 EXPORTING

   filename                = l_fullpath

 CHANGING

   data_tab                = lt_export

 EXCEPTIONS

   file_write_error        = 1

   no_batch                = 2

   gui_refuse_filetransfer = 3

   invalid_type            = 4

   no_authority            = 5

   unknown_error           = 6

   header_not_allowed      = 7

   separator_not_allowed   = 8

   filesize_not_allowed    = 9

   header_too_long         = 10

   dp_error_create         = 11

   dp_error_send           = 12

   dp_error_write          = 13

   unknown_dp_error        = 14

   access_denied           = 15

   dp_out_of_memory        = 16

   disk_full               = 17

   dp_timeout              = 18

   file_not_found          = 19

   dataprovider_exception  = 20

   control_flush_error     = 21

   not_supported_by_gui    = 22

   error_no_gui            = 23

   OTHERS                  = 24.

FORM format_timestamp USING iv_timestamp TYPE comt_valid_from CHANGING cv_line.

 CONVERT TIME STAMP iv_timestamp TIME ZONE 'UTC' INTO DATE DATA(date)

    TIME DATA(time).

 CLEAR: cv_line.

 cv_line = |{ date DATE = ISO } { time TIME = ISO }|.

ENDFORM.Those entries are exported from ABAP server to my local laptop stored in txt format.image.pngNow go back to PostgreSQL console, choose import from context menu:image.pngLoad the local text file:image.pngAnd you can see import successful notification:image.pngClick detail hyperlink, and you see totally 94331 lines are imported from ABAP server.image.pngJust do some double click to confirm whether the data imported are exactly equal to the records in ABAP server.

image.png

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
多表利用DIH批量导入数据并建立索引注意事项
  如果希望同时对多个表进行全文检索,那我们该如何处理呢?利用DIH导入数据并建立索引时。schema.xml中配置了uniqueKey为id id   如果多表主键都为id的话索引会被覆盖   由于id是唯一键,如果id重复索引会被覆盖掉。
721 0
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
10018 0
PostgreSQL 与 MSSQL(SQL Server) 之间 数据相互迁移、导入、导出测试
标签 PostgreSQL , ms sql , SQL Server 背景 测试表结构 create table test (id int, info text); 从 PostgreSQL 导入 MSSQL MS SQL bcp与BULK INSERT都不支持stdin,所以我这里使用落地到文件的方法,从PostgreSQL导入MS SQL。
3385 0
如何把数据导入不同的表空间?
如何把数据导入不同的表空间?作者:eygle | English Version 【版权声明:转载时请务必以超链接形式标明文章原始出处和作者信息及本声明】链接:http://www.
531 0
阿里云服务器端口号设置
阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的 3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。
10880 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
13821 0
postgresql:数据库导入导出
版权声明:欢迎转载,请注明沉默王二原创。 https://blog.csdn.net/qing_gee/article/details/45010021 通过我的电脑-》属...
748 0
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
7344 0
2315
文章
0
问答
来源圈子
更多
+ 订阅
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载