在Oracle数据库中如何把两张表关联起来,多对一或者一对一一对多。请写明语句 谢谢!!!

如题所述

有两种办法:
第一种方法是通过外键
假设有两张表,
A表(AId,AName) B(BId,BName)表 ,要想把这两者关联起来的话。可以通过外键来关联,在B表或者A表中添加一个外键。这里就以B表把B(BId,AId(外键),BName),这样通过外键两张表就可以联系起来了,例如我们在查询的时候通过AId就可以关联查询两张表的数据了。
第二种方法就是增加一张表:
还是拿A表(AId,AName) B(BId,BName)表来举例把,
我们可以增加个C表来联系AB表之间的关系
C表中只要放AB表的主键就行了
C(AId,BId),这样我们就可以通过C表来关联AB表了。
呵呵
温馨提示:答案为网友推荐,仅供参考
第1个回答  2011-05-30
必须要有关联字段,如T1表的id字段与t2表的id字段为关联字段则:
select * from t1,t2 where t1.id=t2.id
只要各张表有关联字段,写法直接在上面的基础上累加!
第2个回答  2011-05-30
你的a,b,c是你所指的三个别名吧?是因为你把子查询作为i表,而其中的a 把语句贴下,我帮你看下。追问

create table t_orderDetail
( ID number constraint s_orderDetail primary key, ---订单明细ID
orderID varchar2(20) not null references t_order(orderID), ---订单ID
goodsID number not null , ---商品ID
goodsName varchar2(200) not null, --商品名称
);
你帮我把这两张表 一对一 一对多 多对一关联起来 插入语句 谢谢

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网