SAP DY-02

SAP DY-02

数据库

  1. SE16 可以查看数据库相关的东西。设置中有个用户参数,可以选择查看数据库表的显示的方式。如视图格式,显示字段名还是字段文本。
  2. SE11中我们可以自建表。字段类型可以属于一个字段域的。双击可以看到一些具体的属性。可以尝试自建表,自定义字段类型,自定义域。对于数量型(货币型)的字段类型,必须有有一个参考表和一个参考字段。一般选择一个主数据透明表。
  3. 视图可以在其中定义表单关系,从多个表中抓取数据放入其中,跟我们以前的关系型的数据库一样

OPEN SQL

大致同以前学习的表。

待扩充。。。。

以下引用:SAP ABAP内表OCCURS,WORK AREA等相关
>

先来看看内表是什么东西。顾名思义内表是一张存在内存中的表。首先,它是由很多work
area组成。所谓work
area,说通俗一点即是表的一行,占用一定的内存空间。那么为什么要有内表存在呢?原因在于我们直接在数据库中取数速度慢,而内存的速度远远高于存储数据的硬盘的速度,我们将数据库表拷贝至存在于内存中的内表上,再在内表上进行查询、取数等操作,效率将大大提高。这也是近些年SAP大力推销其内存计算产品的一个原因。

先看一段关于内表的小程序:

DATA: BEGIN OF LINE,
      LINE1 TYPE I,
      LINE2 TYPE I,
      END OF LINE.

DATA: BEGIN OF LINE OCCURS 0,
      LINE1 TYPE I,
      LINE2 TYPE I,
      END OF LINE.

前者声明了一个work area,后者则声明了一个internal table。
对比这两段程序,可以看出二者的区别就在于一个包含OCCURS,而另一个不包含。OCCURS的意思是为这个内表分配多大的空间,可以简单的理解为为内表分配了若干行的空间。第一个程序没有使用occurs,所以它是一个work area,我们可以简单的理解成它是内表的一行,因为内表是由若干个work area组成的。实际上我们可以先定义一行的work area然后通过APPEND行的方式,来实现内表的定义,因此occurs现在就并不常用了。

内表与工作区在语法上有所区分,但在实际上可以理解为相近的东西,即内表是由工作区组成的。
内表操作对应的关键字有type table of, type line of等,而单独使用type则是对于工作区而言。

再看一段关于内表声明的小程序:

DATA: BEGIN OF LINE OCCURS 0,
      LINE1 TYPE I,
      LIEN2 TYPE I,
      END OF LINE,
      ITAB LIKE TABLE OF LINE.

TYPES: BEGIN OF LINE,
      LINE1 TYPE I,
      LINE2 TYPE I,
      END OF LINE.
DATA: ITAB TYPE TABLE OF LINE.

这边说明了DATA与TYPES的区别,因为这种区别导致了内表不同的声明方法。DATA声明的东西对应于c语言中的初始化变量,是已经分配了内存空间的了。而type声明的东西相当于一种变量类型,对应于c语言中的结构体,需要为它赋值、初始化。

select … INTO ()这个左括号后面不能有空格,否则会报错

  1. 多表连接,可用()括起来连接
tables: ekko, ekpo.
DATA i_ekko like table of ekko with header line. "i_ekko既是一个内表,又是一个与该内表结构相同的工作区
DATA i_ekpo like table of ekpo with header line. 
select single * from EKKO as a inner join EKPO as b on a~ebeln = b~ebeln into corresponding fields of I_EKKP. 
APPEND i_ekko.

LOOP at i_ekko.
ENDLOOP.

singele 查询单条数据,endselect 多条数据。如果没有这两样则可以写成into corresponding fields of table i_ekko. 并且要去掉append i_ekko。即查出的结果直接当成一个表放进i_ekko中。
select * … into table …会把原有的数据清空掉,而使用select * … appending table … 则只是追加上去不会清空。 (且 into/appending后面如果加了table 则不需要使用endselect了)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值