【ABAP系列】SAP 使用事务码DBCO实现SAP链接外部数据库以及读取例程

前言部分
大家可以关注我的公众号,公众号里的排版更好,阅读更舒适。
正文部分
一、链接SQLServer数据库
执行事务码DBCO,点新条目按钮,填写如下图所示信息
这里的连接信息很接近 Sql Server 的连接字符串,但是参数名略有不同。指定主机IP、数据库名即可。

二、链接DB2数据库
执行事务码DBCO,点新条目按钮,填写如下图所示信息
连接信息看上去比较直接,分别是数据库名、端口号、主机IP地址。

三、链接Oracle数据库
执行事务码DBCO,点新条目按钮,填写如下图所示信息
连接信息比较隐晦,必须在 SAP 应用服务器上安装 Oracle Client,然后设置连接,并在这里将连接信息指定与连接名一致。
为了防止乱码,我们还应该在链接信息后加如下参数:ZHS16GBK
格式如下:ORCL.WORLD:ZHS16GBK

四、链接MaxDB数据库
执行事务码DBCO,点新条目按钮,填写如下图所示信息
MaxDB 是 SAP 自己的数据库,这个连接则是 NetWeaver Developer 版中默认创建的一个连接

访问外部数据库
1. 实例:SAP系统访问PeopleSoft数据库
*&----------------------------------------------------------------------------------------------------- &*
*& 定义常量 &*
*&------------------------------------------------------------------------------------------------------&*
CONSTANTS: CNS_YGJK TYPE C LENGTH VALUE 'HR9DEV'.
**打开连接
EXEC SQL.
CONNECT TO :CNS_YGJK
ENDEXEC.
***获取人事数据
TRY.
EXEC SQL PERFORMING PF_GET_RS.
SELECT MANDT,
ZID,
OTYPE,
INFTY,
ZUPDATE,
OPERA,
ZDATA
INTO :WA_HR01-MANDT,
:WA_HR01-ZID,
:WA_HR01-OTYPE,
:WA_HR01-INFTY,
:WA_HR01-ZUPDATE,
:WA_HR01-OPERA,
:WA_HR01-ZDATA
FROM z00hrjzlch01
WHERE SAP_GET = ''
ENDEXEC.
**处理人事数据
IF IT_HR01[] IS NOT INITIAL.
LOOP AT IT_HR01 INTO WA_HR01.
EXEC SQL.
UPDATE z00hrjzlch01
SET SAP_GET = 'X'
WHERE MANDT = :WA_HR01-MANDT
AND ZID = :WA_HR01-ZID
ENDEXEC.
IF SY-SUBRC = .
*********更新ERP数据库表
EXEC SQL.
COMMIT
ENDEXEC.
MODIFY Z00HRJZLCH01 FROM WA_HR01.
COMMIT WORK.
ENDIF.
ENDLOOP.
ENDIF.
**关闭连接
EXEC SQL.
DISCONNECT :CNS_YGJK
ENDEXEC.
**获取异常
CATCH CX_SY_NATIVE_SQL_ERROR INTO CL_EXEC_REF.
EXIT.
CATCH CX_SQL_EXCEPTION INTO CL_SQLERR_REF.
EXIT.
ENDTRY.
*&---------------------------------------------------------------------*
*& Form PF_GET_ZZ
*&---------------------------------------------------------------------*
* 组织增量数据
*----------------------------------------------------------------------*
FORM PF_GET_ZZ .
APPEND WA_HR02 TO IT_HR02.
ENDFORM.
事务代码:DBCO查看,SAP系统现存的连接

程序中使用的是连接【HR9DEV.WORLD】,双击这行如下图所示:

先在SAP底层ORACLE数据库编辑TNS文件,一般由BASIS配置完成,配置路径:DIR_ORAHOME->network->admin->tnsnames.ora;配置完成后我们可以用事务码:AL11查看配置是否正确,AL11查看连接【HR9DEV.WORLD】具体配置

【ABAP系列】SAP 使用事务码DBCO实现SAP链接外部数据库以及读取例程的更多相关文章
- 【ABAP系列】【第五篇】SAP ABAP7.50 之用户接口
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列][第五篇]SAP ABAP7.5 ...
- 【ABAP系列】【第六篇】SAP ABAP7.50 之隐式增强
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列][第六篇]SAP ABAP7.5 ...
- SAP 用事务码SQVI 做简单报表 .
集团计划总监要去德国参展,要一份离当前日期最近的出口欧美国家产品单价. 需要从A903,MARA,KONP,MATK 这4张表里取数. 1)Tcode:SQVI进入,如图 2) 在快速浏览处输入名称: ...
- SAP Idoc 事务码
SALE Display ALE Customizing SM59 RFC Destinations (Display/Maintain) BD64 Maintenance of Distributi ...
- 【FICO系列】SAP FICO总账余额相关的事务码
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[FICO系列]SAP FICO总账余额相关的事 ...
- 【ABAP系列】SAP ABAP 为表维护生成器创建事务代码
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP 为表维护生成器 ...
- [SAP ABAP开发技术总结]ABAP常用事务码
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
- ABAP常用事务码
开发----------------------------------------------- SE51 屏幕制作 SE91 MESSAGE OBJECT SE80 对象浏览器(可以建开发类 ...
- 【ABAP系列】SAP ABAP 资产类BAPI过账 BAPI_ACC_DOCUMENT_POST
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP 资产类BAPI ...
随机推荐
- .Net界面开发必备!DevExpress Blazor UI全新组件助力界面开发
行业领先的.NET界面控件DevExpress 正式发布了v19.1版本,DevExpress UI for Blazor/ Razor组件附带7个用户界面组件(包括Data Grid和Pivot G ...
- HDFS知识点
1.通过代码验证集群的配置文件的优先级 HDFS文件上传 1.编写源代码 @Test public void testCopyFromLocalFile() throws IOException, I ...
- Javaweb运行时出现Tomcat错误
运行web项目时出现如下错误如何解决 重新配置路径,具体可参考 https://www.cnblogs.com/xueqiuxiang/p/12087947.html 中提到的配置Tomca ...
- java——通过GenericObjectPool获取到的资源,调用close()方法会close还是returnObject?
一种优雅的关闭资源的方式是使用try(){}cache(){} 就像这样: 这时候,try()里面的资源会在return语句执行结束之后自动调用close()方法,那么问题来了,当我们使用连接池的时候 ...
- Jenkins-邮件模板
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- 课时5:POW,POS,DPOS(矿工/矿机,工作证明)
比特币钱包
- tomcat下载与安装
https://www.cnblogs.com/limn/p/9358657.html
- 【IOI2018】机械娃娃
看到的时候感到很不可做,因为所有的开关都要状态归零.因此可以得到两分的好成绩. --然后 yhx-12243 说:这不是线段树优化建图吗? 于是我获得了启发,会做了-- 还不是和上次一样,通过提示做出 ...
- AcWing:175. 电路维修(bfs)
达达是来自异世界的魔女,她在漫无目的地四处漂流的时候,遇到了善良的少女翰翰,从而被收留在地球上. 翰翰的家里有一辆飞行车. 有一天飞行车的电路板突然出现了故障,导致无法启动. 电路板的整体结构是一个R ...
- codeforces gym #101873B. Buildings(Polya定理)
参考博客: https://blog.csdn.net/liangzhaoyang1/article/details/72639208 题目链接: https://codeforces.com/gym ...