abap中 内表的问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了abap中 内表的问题相关的知识,希望对你有一定的参考价值。

data:begin of gt_data ,
matnr like mard-matnr,
werks like mard-werks,
lgort like mard-lgort,
labst like mard-labst,
end of gt_data.
data: so_data like table of gt_data.
select matnr
werks
lgort
labst
into table gt_data
请教 上面这个程序中 select 后面是不是一定得是这4个关键字,可以少一个吗?如果在上面结构体中再多定义几个元素,那么在into后面这个内表还可以这样用吗,求解~

其实大体就是想知道内表中的字段可以比select要取的字段多吗!

select 后面的字段如果比into table后面的字段多,程序运行的时候就会Dump掉,这时候你需要用SELECT XXX INTO CORRESPONDING FIELDS OF TABLE YYY, 但是这时候你需要select后面的字段名要与table后面的内表中的字段名一一对应。如果用这个语法,字段名不对应的就没有值。
如果select后的字段与into table的内表中的字段数量一样,且table中的字段类型与数据库表中的一样,用select XX into table YYY的时候不会Dump,但字段类型的顺序要一样。
例如:
DATA: BEGIN OF wa_a,
bname TYPE xubname,
spdb TYPE xuspdb,
col1 TYPE xuspda,
END OF wa_a,
it_a LIKE TABLE OF wa_a.

SELECT bname
spdb
spda
FROM usr01
INTO TABLE it_a.
这样可以取到3个字段的值

DATA: BEGIN OF wa_a,
bname TYPE xubname,
spdb TYPE xuspdb,
col1 TYPE xuspda,
END OF wa_a,
it_a LIKE TABLE OF wa_a.

SELECT bname
spdb
spda
FROM usr01
INTO CORRESPONDING FIELDS OF TABLE it_a.
这样可以取到前两个字段的值

DATA: BEGIN OF wa_a,
bname TYPE xubname,
spdb TYPE xuspdb,
END OF wa_a,
it_a LIKE TABLE OF wa_a.

SELECT bname
spdb
spda
FROM usr01
INTO TABLE it_a.
这样程序就会Dump
参考技术A SELECT 后面的字段 与 into table 后面的内表结构 有什么必然关系

如果说你select后面没写labst 就是gt_data中的labst没有数据 其它正常
这种情况太普遍了 gt_data中字段比select后面多
因为这些字段这个地方不用别的地方可能用

如果说你定义的gt_data中没有labst,但是select后面有 那gt_data种labst肯定也没数据
这个一般不会这么写 既然写在了select后面 肯定需要这个字段 但是接收数据的内表里没有
只有在某些特殊情况下才这么去写追问

可是我在运行时如果gt_data中字段比select后面多 它会报错内表字段比所选字段多,应该怎么解决?

追答

仅仅是字段多 肯定不会报错 一般是一个黄色警告提示 不用管

以上是关于abap中 内表的问题的主要内容,如果未能解决你的问题,请参考以下文章

ABAP中clearrefreshfree三者清空内表的区别

abap怎么把字段类型不一样的一个内表的数据填充到另外一个内表中。

ABAP基础篇1 内表

abap 内表的结构体比数据库的结构体少一个client字段,怎么把内表的数据添加到数据库中?

ABAP 内表的行列转换-NEW

XML文件与ABAP结构/内表的转换