在第一部分中,我们选择了一些记录,并使用Session选项创建了一个'outfile'来输出文件。我希望这两个部分都是一个SQL。在第2部分中,我必须包括最后一个表的列。 ad.IARCC9目前的数据结果如下:数据显示部分#按照我们刚需要的日期销售,包括最后一个col,这是推荐给供应商。
QUANTITY WWDOCD PART NO.
1.00 20,121,205 MYAABC
1.00 20,130,619 MYAABC
1.00 20,130,619 MYAABC
1.00 20,130,726 MYAABC
25.00 20,120,629 AC-GL9
20.00 20,120,502 AC-GL9
30.00 20,120,425 AC-GL9
30.00 20,120,419 AC-GL9
20.00 20,120,411 AC-GL9
30.00 20,120,321 AC-GL9
第1部分。
SELECT *
FROM astccdta.Oeinh48 a
JOIN astdta.IcDet1 b ON b.Itcom# = a.IhCom# AND b.ItTrn# = a.IhIdc#
WHERE A.IHORDD > 20120101 AND b.ItTscc = 'I'
--------
第2部分。
SELECT ItQty#,IhDocd,ItPRT#
FROM pklib.Fileout1 a
JOIN astdta.icEct1 b ON b.CtCom# = a.ItCom# AND b.CtCtr# = ' ' AND b.CtPrt# =a.ItPrt#
JOIN astdta.Audia ad ON ad.IAprt# = a.ItPrt#
WHERE ad.IARCC9 > ''
ORDER BY ad.IARCC9
答案 0 :(得分:2)
您正试图避免临时中间文件。
您在武器库中想要的工具称为common table expression [CTE]。这是一种强大的技术,允许您将复杂的SELECT statement构建为一系列逻辑构建块。
你可以像这样放在一起:
with f as
(
SELECT *
FROM astccdta.Oeinh48 a
JOIN astdta.IcDet1 b ON b.Itcom# = a.IhCom#
AND b.ItTrn# = a.IhIdc#
WHERE A.IHORDD > 20120101
AND b.ItTscc = 'I'
)
SELECT ItQty#,IhDocd,ItPRT#
FROM f -- this refers to the result set of the CTE above
JOIN astdta.icEct1 b ON b.CtCom# = f.ItCom#
AND b.CtPrt# = f.ItPrt#
AND b.CtCtr# = ' '
JOIN astdta.Audia d ON d.IAprt# = f.ItPrt#
WHERE a.IARCC9 > ''
ORDER BY d.IARCC9;
附加说明:您可以轻松地使用SQL本身来创建outfile,而不是使用STRSQL会话选项。只需在查询周围添加一个小包装:
CREATE TABLE fileout as
(
-- your query goes here
)
WITH DATA;
或者,如果您想要添加到现有文件
INSERT INTO fileout
-- your query goes here
;
通过使用SQL来编写结果而不是会话设置,您已经创建了一个可以从其他接口运行的解决方案。