前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >SAP ABAP——OPEN SQL(四)【FROM】

SAP ABAP——OPEN SQL(四)【FROM】

作者头像
THUNDER王
发布2023-02-23 12:58:08
发布2023-02-23 12:58:08
33700
代码可运行
举报
运行总次数:0
代码可运行

 💬个人网站:【芒果个人日志】​​​​​​ 💬原文地址:SAP ABAP——OPEN SQL(四)【FROM】 - 芒果个人日志 (wyz-math.cn)

💂作者简介: THUNDER王,一名热爱财税和SAP ABAP编程以及热爱分享的博主。目前于江西师范大学会计学专业大二本科在读,同时任汉硕云(广东)科技有限公司ABAP开发顾问。在学习工作中,我通常使用偏后端的开发语言ABAP,SQL进行任务的完成,对SAP企业管理系统,SAP ABAP开发和数据库具有较深入的研究。

💅文章概要:本文主要介绍一下SAP ABAP中OPEN SQL的FROM语句

🤟每日一言:当你知道你不在是你的时候,你才是真正的你! 9、充沛的精力加上顽强的决心,曾经创造出许多奇迹。

目录

FROM语句选项

FROM中选择表

- 选择静态表

- 选择动态表(在页面动态地输入数据库表sflight查询到相关的数据)

JOIN语句

- INNER JOIN

- LEFT OUTER JOIN

FROM语句选项

语句

说明

CLIENT SPECIFIED

解除自动client设置

BYPASSING BUFFER

不会从SAP本地缓冲器中读取数据

UP TO n ROWS

限制查询的个数


FROM中选择表

- 选择静态表

代码语言:javascript
代码运行次数:0
运行
复制
SELECT ... FROM <dtba> [AS <alias>] WHERE <condition>

- 选择动态表(在页面动态地输入数据库表sflight查询到相关的数据)

案例演示代码:

代码语言:javascript
代码运行次数:0
运行
复制
DATA:GS_SFLIGHT TYPE SFLIGHT.
PARAMETERS P_SF TYPE CHAR20.

SELECT * FROM (P_SF) INTO GS_SFLIGHT UP TO 1 ROWS.
 WRITE:GS_SFLIGHT-CARRID, GS_SFLIGHT-CONNID.
ENDSELECT.

动态表

查询效果


JOIN语句

JOIN语句是ABAP OPEN SQL中用来在查询多个表中数据时使用的一种语法,能够将多个数据库表进行连接查询(其中JOIN语句还细化分为了INNER JOIN 和 OUTER JOIN 其中若不指定OUTER JOIN 则JOIN默认为INNER JOIN),其中JOIN语句的基本语法如下:

代码语言:javascript
代码运行次数:0
运行
复制
SELECT...FROM <dbta1> [AS <alias>] [INNER][LEFT OUTER] JOIN <dbta2> [AS <alias>] ON <condition> [WHERE <condition>] [UP TO n ROWS]

- INNER JOIN

INNER JOIN为内连接,用于查询两个表中相同的数据,其中案例代码及效果如下:

代码语言:javascript
代码运行次数:0
运行
复制
 DATA:BEGIN OF GS_SFLIGHT,
  ZCARRID LIKE SFLIGHT-CARRID,
  ZCARRNAME LIKE SCARR-CARRNAME,
 END OF GS_SFLIGHT.

  SELECT a~CARRID b~CARRNAME INTO GS_SFLIGHT FROM SFLIGHT AS a INNER JOIN SCARR AS b ON a~CARRID = 
   b~CARRID UP TO 1 ROWS
   WHERE a~CARRID = 'AC' .
   WRITE:/ GS_SFLIGHT-ZCARRID,GS_SFLIGHT-ZCARRNAME.
  ENDSELECT.

可以看到结果显示返回了两个表中相同的数据!并且UP TO 1 ROWS限制了返回的结果行数!

案例效果

SCARR数据库表

SFLIGHT数据库表

- LEFT OUTER JOIN

LEFT OUTER JOIN为左外连接(ABAP OPEN SQL中目前只支持左外连接),此语句以左边基本表作为基准表读取数据(能够返回左边表拥有但右边表没有的数据)其中案例代码及效果如下:

代码语言:javascript
代码运行次数:0
运行
复制
   DATA:BEGIN OF GS_SFLIGHT,
   ZCARRID LIKE SFLIGHT-CARRID,
   ZCURRCODE LIKE SCARR-CURRCODE,
   END OF GS_SFLIGHT.

   SELECT a~CARRID b~CURRCODE INTO GS_SFLIGHT FROM SFLIGHT AS a LEFT OUTER JOIN SCARR AS b ON 
   a~CARRID = b~CARRID .
   WRITE:/ GS_SFLIGHT-ZCARRID,GS_SFLIGHT-ZCURRCODE.
   ENDSELECT.

可以看到结果显示返回了左边表中拥有但是右边表中不具有的数据(SFLIGHT中具有CARRID为SQ的数据,但是SCARR中不具有CARRID为SQ的数据)!

左外连接效果

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-11-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • FROM语句选项
  • FROM中选择表
    • - 选择静态表
    • - 选择动态表(在页面动态地输入数据库表sflight查询到相关的数据)
  • JOIN语句
    • - INNER JOIN
    • - LEFT OUTER JOIN
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档