我正在做两张桌子。一个包含符合我的筛选条件的657行,另一个包含193条记录。
我使用Oracle的"AFAIK“语法成功地加入了它们:
select
ecp.portfolio_acct, ecp.posn_id cost_posn_id, ecp.asset_id
from MID_COST_POSITION ecp, MID_CASH_POSITION cas
where ecp.portfolio_acct = 10183306
and ecp.portfolio_acct = cas.portfolio_acct(+)
and ecp.asset_id = cas.asset_id(+)
;但是,我似乎无法使用ANSI-SQL (或ISO-sql)复制这些结果:
select
ecp.portfolio_acct, ecp.posn_id cost_posn_id, ecp.asset_id
from MID_COST_POSITION ecp
LEFT OUTER JOIN MID_CASH_POSITION cas
on ecp.portfolio_acct = cas.portfolio_acct
where ecp.asset_id = cas.asset_id
and ecp.portfolio_acct = 10183306
;我尝试过各种连接,但都没有成功。在第一个例子中,我不得不外连接两个独立的字段,我不知道如何使用ANSI-SQL来完成这一点。
我很感谢任何人能提供的任何指导。谢谢!
发布于 2017-06-14 00:57:42
select
ecp.portfolio_acct, ecp.posn_id cost_posn_id, ecp.asset_id
from MID_COST_POSITION ecp
LEFT OUTER JOIN MID_CASH_POSITION cas
on ecp.portfolio_acct = cas.portfolio_acct
and ecp.asset_id = cas.asset_id
Where ecp.portfolio_acct = 10183306
;您将其转换为具有以下where条件的内连接,因为它现在必须在结果集中满足该条件:
ecp.asset_id = cas.asset_idhttps://stackoverflow.com/questions/44527373
复制相似问题