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的内表中的字段数量一样,且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怎么把字段类型不一样的一个内表的数据填充到另外一个内表中。