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

简介: 本文主要介绍SAP ABAP中OPEN SQL的FROM语句

本文主要介绍SAP ABAP中OPEN SQL的FROM语句


FROM语句选项

语句 说明
CLIENT SPECIFIED 解除自动client设置
BYPASSING BUFFER 不会从SAP本地缓冲器中读取数据
UP TO n ROWS 限制查询的个数


选择表

- 选择静态表

SELECT ... FROM <dtba> [AS <alias>] WHERE <condition>

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

案例演示代码:

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.

00062e86a3e72953e11ecbb061cfa2c.png

1c175334b46d9594efd6711568e3891.png



JOIN

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

SELECT...FROM <dbta1> [AS <alias>] [INNER][LEFT OUTER] JOIN <dbta2> [AS <alias>] ON <condition> [WHERE <condition>] [UP TO n ROWS]

- INNER JOIN

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

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限制了返回的结果行数!

c7a7a0fc092ff24e320259086ff1cf1.png

1d571aff1cd249722b3f2c7d06811d0.png

6043e1324b4efb40195f8857c71a97d.png

- LEFT OUTER JOIN

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

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的数据)!

f37374604064bb1ba96c1dfc760f26d.png

目录
相关文章
SAP ABAP 程序调用设置成后台作业模式
ABAP 程序调用设置成后台作业模式
523 0
SAP ABAP 内表排序 动态字段排序
对于动态内表排序引用ABAP_SORTORDER_TAB
298 0
|
SQL 设计模式 前端开发
【置顶】SAP ABAP开发实战——从入门到精通系列目录
本文章为SAP ABAP开发实战——从入门到精通系列的目录以及关于该教程的后续写作计划表
1593 0
【置顶】SAP ABAP开发实战——从入门到精通系列目录
|
SQL
SAP ABAP-OPENSQL-数值函数简介
S4中针对OPENSQL新提供一些函数
139 0
|
SQL
SAP ABAP-OPENSQL-字符串函数介绍
S4中SQL新语法字符串函数
209 0
|
SQL
SAP ABAP-OPENSQL-日期/时间戳函数
S4提供针对OPENSQL一些新的SQL函数调用,本文展示相关函数的使用
661 0
SAP ABAP-删除工序示例代码
ABAP-删除工序示例代码
171 0
SAP ABAP 检查事务码权限
检查用户是否有自开发事务码的权限
158 0
|
BI
SAP ABAP在线预览文档对象的开发实现
应用场景:有些定制化开发(报表/功能增强等)完成之后,客户需要将其操作手册或者相关文档放在某个报表的初始画面,供实际操作者在线查阅,当然这个功能也同样类似于模板的下载,这里就以在线预览(直接打开)为例进行说明。
225 0
SAP ABAP字符串拼接保留空格
字符串操作保留空格
1090 0