SAP-ABAP-SELECT语法SQL语法详解

  1. select语句的基础语法格式

SELECT <FIELD>  FROM <TABLE>  WHERE <CONDITION>  INTO  <LT_TAB>

<FIELD>代表想要搜索的表字段,用TABLE~FIELD表示,当FIELD唯一确认在一个表时可省略TABLE指定

<TABLE>代表从哪个取数据

<CONDITION> 代表取出的数据要满足哪些条件

<LT_TAB> 代表存储在本程序的哪个位置

   代码示例

   上图代码的意思是从SPFLI表取出CARRID字段和CONNID字段,限制条件是DEPTIME大于120000,取出来的数据存到LT_TAB字段。

若想取出所有数据可以把改成

若想新增其他限制条件可以往后面并列条件其他

  1. SELECT 的连表

连表的目的是一次取出多个表的数据,根据某些字段关联其他表

INNER JOIN :全连接,连接的两个表连接字段必须能一一对应上,此条数据才能连表成功,连表失败的数据不会展示在结果表中

LEFT JOIN :左连接,连接的两个表连接字段必须能一一对应上,此条数据才能连表成功,以连接表为主表,连表失败后主表数据可以取出来,但是被连表数据无法取出来

RIGHT JOIN :右链接,连接的两个表连接字段必须能一一对应上,此条数据才能连表成功,以连接表为主表,连表失败后主表数据无法取出来,但是被连表数据可以取出来

以下列数据为例展示表连接,采购订单Z300138357有14个行项目,只有12行进行了收货,其中20行和30行没有收货,具体数据如下图所示

若是全连接,未收货的数据便不会取出来,可以看到下图结果表中没有20行和30行

若是左连接,未收货的数据会取出来,可以看到下图结果表中有20行和30行,但是表中取EKBE的字段不会展示出来

若是左连接,未收货的数据会取出来,可以看到下图结果表中有20行和30行,但是表中取EKPO的字段不会展示出来

 

  1. 聚合函数MAX,MIN,AVG

求某个数据最大值,最小值,平均值可以在字段清单使用聚合函数+括号+要求和的字段+字段别名+GROUP BY 分组,具体代码及结果如下图所示

  1. 聚合函数COUNT

求出满足条件是数据条目数,COUNT后面不加字段名称用*表示条目数, COUNTAS LINES + GROUP BY 分组具体代码及结果如下图所示

  1. 聚合函数SUM

SUM后面加需要求和的字段,不能是文本字段,GROUP BY 分组具体代码及结果如下图所示

  1. 数字类型字段在SELECT中的运算符

SELECT 中支持的运算符有加法,减法,和乘法,没有除法,运算的对象可以是所取的表中是数据(只能是数字类型),也可以是固定数字,不能是变量,多重计算要常用括号。示例代码 如下

  1. CHAR类型字段拼接拆分操作

拼接拆分字段仅能针对char类型字段,拼接字段使用&&做拼接,可以拼接常量,表中字段,但不可拼接sql外部变量。拆分字段使用SUBSTRING函数,该函数有三个参数,第一个参数是被拆分的字段,第二个参数是从第几位开始,包括该位,第三个参数是拆分多少位。示例代码及运行结果如下

  1.       其他的数字运算符号

DIV(arg1, arg2)         取整,两个数字必须是整数才能用

MOD(arg1, arg2)     取余,两个数字必须是整数才能用

CEIL(arg)   不小于arg值的最小整数,进1。

FLOOR(arg)  不大于arg值的最小整数,舍1。

DIVISION(arg1, arg2, dec)  arg1除 arg2的结果保留dec位小数,

ROUND(arg, pos)  四舍五入。 如果pos大于0,则将值四舍五入到小数点分隔符右侧的pos位置。 如果不是这样,则将小数点分隔符左侧的位置abs(pos)+1四舍五入。 如果位置数不够,则结果为0。 

9.FOR ALL ENTRIES IN 根据内表参数查询后台表数据

这个语法可以根据内表参数每一行精确的匹配后台表数据,但是使用它需要注意几点

  1. 在使用前必须判断非空,否则select语句相当于没有where条件限制,将取出表中所有数据。
  2. 搜索出的数据必须必须包含该表的全部主键,该方法自带去重功能,完全相同数据将会被删除。
  3. 用来做条件的内表不应该太大,内表每存在一行数据代表select语句多加一个where条件,条件太多影响效率越高

下图为该语法的示例及代码运行结果

10.内表当作后台表直接连表查询

与FOR ALL ENTRIES IN 相同,该语法也是可以将内表的每行数据当作where条件查询后台表数据,但与之不同的是没有非空和主键的限制。具体使用的要点是连接该内表时需要在前面加一个@符号,内表被当作后台表使用时需要用别名指代。具体代码及运行结果如下图。

同样内表也可以作为被连接字段用在被join的表中,代码示例如下,二者的差距在于主表是哪个,展示的数据有多少行

11.子查询语句作为条件查询

当select语句中的限制条件不明确,需要单独用一个sql查出数据时,可将该查询数据作为子查询语句代码示例如下

查询的物料必须扩展了工厂6A01,所有可以将该条件作为子查询

同样子查询可以使用所以的聚合函数如下图示例代码使用了sum函数

上图代码意思是查询采购订单,但是收货数量小于采购订单总数,即查询未收货完成的采购订单

12.字段类型转换CAST语句

    CAST语句一般与其他函数同时使用,当其他函数类型不满足时可以先使用CAST转换为需要的类型,如数字的拆分,行号的加减等,示例代码如下

13.CASE WHEN 分情况取值赋值

     该语句可以在sql中不同情况赋值不同数据,具体使用示例如下。

     CASE WHEN  表达式1  THEN 赋值1

                   WHEN 表达式2 THEN 赋值2

                   ELSE  赋值3   END   AS 字段别名

      示例代码及运行结果如下图

14. DISTINCT删除重复行

         加这个语句自动删除表中完全相同的行示例代码如下

15.SQL跨client取表数据,在SQL里面用USING CLIENT 其他client即可,但是要注意,两个client是同一个服务器才能取到


SELECT * FROM BKPF USING CLIENT '300' INTO TABLE @DATA(LT_TSTC) UP TO 10 ROWS.
  

附:部分sql代码示例

  • 14
    点赞
  • 141
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
《从实例学SAP ABAP编程1-10章》是一本SAP ABAP编程的经典入门教材。本书从简单的SAP ABAP编程入手,通过多个实例向读者展示了SAP ABAP编程的核心概念和语法。 在第一章中,本书通过一个简单的例子介绍了SAP ABAP编程的基础知识,讲解了ABAP编辑器、ABAP数据字典和ABAP Workbench等重要工具的用法。 在第二章中,本书通过一个简单的例子向读者介绍了ABAP表格的创建和维护,并讲解了一些与表格相关的SAP ABAP编程的语法和概念。 在第三章中,本书介绍了SAP ABAP编程中的面向对象编程,通过几个例子向读者展示了如何使用类、对象和继承等概念进行SAP ABAP编程。 在第四章中,本书介绍了SAP ABAP编程中的函数模块,向读者讲解了如何创建和调用函数模块,以及如何在SAP系统中使用函数模块。 在第五章中,本书介绍了SAP ABAP编程中的异常处理,向读者讲解了如何使用TRY/CATCH语句处理SAP系统中的异常情况。 在第六章中,本书介绍了SAP ABAP编程中的Web服务,向读者讲解了如何创建和使用SAP系统中的Web服务,以及如何使用HTTP和SOAP协议进行数据通信。 在第七章中,本书介绍了SAP ABAP编程中的ALV报表,向读者讲解了如何创建和维护SAP系统中的ALV报表,以及如何对报表进行数据操作和定制。 在第八章中,本书介绍了SAP ABAP编程中的BADI和Enhancement点,向读者讲解了如何使用BADI和Enhancement点扩展和修改SAP系统中的业务逻辑。 在第九章中,本书介绍了SAP ABAP编程中的Smart Form,向读者讲解了如何使用Smart Form创建和维护SAP系统中的表单。 在第十章中,本书介绍了SAP ABAP编程中的SAP HANA数据库,向读者讲解了如何使用SAP HANA数据库进行高效的数据处理和分析。 通过阅读本书,读者可以快速掌握SAP ABAP编程的核心知识和技能,从而能够独立进行SAP系统的开发和维护工作。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值