oracle表间多字段连接

问题如下:

SELECT *
  FROM table1 a, table2 b,
 WHERE a.1 = b.1
   AND a.2 = b.2
   AND a.3 = b.3
   ----------
   初始 a表里有数据  b表里是空的 想用a的那三个字段联合起来 join b 的那三个字段

方法1:

select * from
table1 left outer join table2
on a.1=b.1 and a.2=b.2 and  a.3=b.3

方法2:

<!--StartFragment -->
SELECT a.*
  FROM table1 a, table2 b,
 WHERE a.1 = b.1(+)
   AND a.2 = b.2(+)
   AND a.3 = b.3(+)
方法3:
<!--StartFragment -->
a.1||a.2||a.3做主键
b也同样处理,然后再外连接
SELECT a.*
  FROM (select a.1||a.2||a.3 al from table1) a, (select b.1||b.2||b.3 bl from table2) b,
 WHERE a.al = b.bl(+)
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值