发布网友 发布时间:2022-04-23 06:25
共2个回答
热心网友 时间:2023-10-05 07:10
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
热心网友 时间:2023-10-05 07:10
SELECT 后面的字段 与 into table 后面的内表结构 有什么必然关系
如果说你select后面没写labst 就是gt_data中的labst没有数据 其它正常
这种情况太普遍了 gt_data中字段比select后面多
因为这些字段这个地方不用别的地方可能用
如果说你定义的gt_data中没有labst,但是select后面有 那gt_data种labst肯定也没数据
这个一般不会这么写 既然写在了select后面 肯定需要这个字段 但是接收数据的内表里没有
只有在某些特殊情况下才这么去写追问可是我在运行时如果gt_data中字段比select后面多 它会报错内表字段比所选字段多,应该怎么解决?
追答仅仅是字段多 肯定不会报错 一般是一个*警告提示 不用管