abap中查询条件的数据类型不同,通过创建新内表来完成查询的话速度会很慢,怎么修改

SELECTbkpf~awkeybkpf~xblnrINTOCORRESPONDINGFIELDSOFTABLEit_bkpfFROMbkpfFORALLENTRIESI... SELECT
bkpf~awkey
bkpf~xblnr
INTO CORRESPONDING FIELDS OF TABLE it_bkpf
FROM bkpf
FOR ALL ENTRIES IN it_vbrk1
WHERE bkpf~awkey = it_vbrk1-vbeln.
此为例子
展开
 我来答
__River__
2012-12-13 · 超过13用户采纳过TA的回答
知道答主
回答量:40
采纳率:0%
帮助的人:35万
展开全部
对于FOR ALL ENTRIES IN it_vbrk1

内表 it_vbrk1如果只使用字段vbeln的话,完全可以定义一个RANGE表来替代该语句。
rt_awkey type range of bkpf-awkey.
rw_awkey like line of rt_awkey.

loop at it_vbrk1 into wa_vbrk1.
rw_awkey -sign = 'I'.
rw_awkey -option = 'EQ'.
rw_awkey -low = wa_vbrk1-vbeln
append rw_awkey to rt_awkey.
endloop.

该SQL语句就可以这样写了:
SELECT
bkpf~awkey
bkpf~xblnr
INTO CORRESPONDING FIELDS OF TABLE it_bkpf
FROM bkpf
WHERE bkpf~awkey in rt_awkey.

另:corredponding 最好不要使用,直接INTO TABLE it_bkpf(注意内表定义字段的顺序和个数,要和SELECT语句后面的想匹配)
素净还帅气丶超人f79
2012-12-25 · TA获得超过338个赞
知道小有建树答主
回答量:185
采纳率:75%
帮助的人:75.7万
展开全部
我做了一个测试,发现我的想法是可行的。
你可以再定义内表it_vbrk1时,将vbeln 定义成 bkpf-awkey。那就可以正常的使用for all entries in 了。
代码如下:

DATA: BEGIN OF it_vbrk OCCURS 0,
vbeln TYPE bkpf-awkey,"发票
fkart TYPE vbrk-fkart,"
END OF it_vbrk.

DATA: BEGIN OF it_bkpf OCCURS 0,
awkey TYPE bkpf-awkey,
xblnr TYPE bkpf-xblnr,
END OF it_bkpf.

SELECT vbeln
fkart
INTO TABLE it_vbrk
FROM vbrk.

SELECT bkpf~awkey
bkpf~xblnr
INTO TABLE it_bkpf
FROM bkpf
FOR ALL ENTRIES IN it_vbrk
WHERE bkpf~awkey = it_vbrk-vbeln.

你试试看可不可以!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
maynuist
2012-12-12 · TA获得超过169个赞
知道小有建树答主
回答量:138
采纳率:0%
帮助的人:81.3万
展开全部
你可以另外定义一个一个内表,将it_vbrk1-vbeln赋值过去,类型定义为与bkpf~awkey 一致,应该效果好一点。。。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友37a963f
2012-12-12 · TA获得超过786个赞
知道小有建树答主
回答量:763
采纳率:0%
帮助的人:317万
展开全部
没看明白
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式