美文网首页简友广场SAP
ABAP基础知识 访问外部数据库-开发篇

ABAP基础知识 访问外部数据库-开发篇

作者: syjf1976_abap | 来源:发表于2021-09-22 17:50 被阅读0次

    点击蓝字 关注我们

    前言

    前文讲解了怎么配置连接外部数据库

    详见链接无峰,公众号:ABAP 技巧与实战ABAP基础知识 访问外部数据库-配置篇

    本文主要介绍通过ABAP语言访问外部数据库的几种方式

    外部数据库配置

    本文示例中的代码访问了两个外部数据库

    MTD : 外部oracle数据库,其中示例表 ZTTEMP 字段( ZZTNO,WERKS)

    S4Q : 外部HANA数据库(开发系统访问测试系统的数据库), 使用表USR02,ZTTEMP

    ABAP访问外部数据库

    通过ABAP访问外部数据库有四种方式.根据不同的情况,可以选择不同的方法.

    • OPEN SQL访问

    • NATIVE SQL 访问

    • ADBC(ABAP Database Connectivity)

    • AMDP ABAP Managed Database Procedures ? (未验证通过)

    OPEN SQL直接访问

    OPEN SQL 访问的限制条件:必须在ABAP数据字典中存在该表名,并且最好同目标系统表结构一致, 一般情况下,用来访问另外一个同版本的ECC数据库.当然,也可以把ECC的表定义语句在目标系统中创建一个同名同结构的表,然后用该方式访问.

    直接访问时,在FROM TABLE 后面添加 CONNECTION s4q .

    s4q是DBCO中建立的和另外一个S/4系统的连接

    01

    报错及处理一

    可能的报错及处理方式

    下图报错的原因是访问ORACLE数据库必须指定一个SCHEMA. 这个可以配置在连接参数中.

    01

    报错及处理二

    出现下面的报错,表示系统尝试使用MANDT限制数据, 此时需要给OPEN SQL 语句添加CLIENT SPECIFIED 强制OPEN SQL 不要补充MANDT限制

    NATIVE SQL访问

    通过NATIVE SQL 访问外部数据库步骤

    • 打开连接

    • 执行SQL命令

    • 关闭连接

    示例代码见文末

    01

    读取多条记录的方式

    • 游标方式    图一

    • 非游标方式 图二

    非游标方式其实隐式使用了游标.性能比游标方式要差.数据量小的时候看不出来. 大量数据读取就能看出二者的性能差异了.

    图三是标准帮助中提示的优劣比较.

    图一

    图二

    图三

    ADBC访问

    ADBC(ABAP Database Connectivity) 是SAP提供的原生SQL(Native SQL)接口API.可以通过ADBC执行任何数据库的原生SQL语句.

    ABAP中有个标准的DEMO程序: ADBC_DEMO 演示了各种SQL语句的调用方式.图四的代码示例给出了SELECT语句的常用写法.

    大概需要如下的过程

    • 创建默认数据库的链接对象

    • 创建一个查询对象

    • 基于sql语句创建一个结果对象

    • 定义传递结果集一个数据对象-内表

    • 获取数据内容

    • 关闭连接

    • 赋值数据到内表

    示例代码详见文末

    通过AMDP 访问?

    AMDP ABAP Managed Database Procedures

    标准ABAP帮助体系中提到访问外部数据库的方法中还有一种AMDP方式.为了完善本文,补充了一个AMDP访问外部数据库表的示例.(验证未通过)

    尝试中发现AMDP只适用与HANA数据库. 并且尝试通过DEMO程序 DEMO_AMDP_CONNECTION 连接外部数据库S4Q. 尝试失败. (报错见图四)

    感觉AMDP 并不支持连接外部数据库.

    图五中示例代码的连接 是 R/3*开头. 帮助中说S/3*是SERVICE CONNECT. 但是不理解有什么用处.

    图四

    图五

    图六

    总结

    ABAP访问外部数据库的几种方式中. OPEN SQL 最简单,但是有很大局限性. NATIVE方式最简单易懂. 性能也最好. 但是不利于代码动态化. ADBC 可以动态的实现数据的读取及内表的赋值.

    前文DB02 SQL编辑器SQL语句自动生成报表 就采用了ADBC访问数据库的方法: 根据语句动态定义选择屏幕,动态定义内表, 读取的数据写入内表呈现.

    详见链接无峰,公众号:ABAP开发技巧SAP工具箱之一键生成报表

    该工具在付费文章中可以获取.

    文中通过AMDP方式连接外部数据库的验证失败. 不推荐使用. 其它三种方式根据实际情况选择使用就好.

    示例代码详见文末.

    THE

    END

    相关文章

      网友评论

        本文标题:ABAP基础知识 访问外部数据库-开发篇

        本文链接:https://www.haomeiwen.com/subject/wjdggltx.html