数据库三表合一

t1


t2


t3


t4


目标:将t1,t3,t4的表内容合并到t2中

/*插入只有t1有的内容*/
insert into t2	(a,b)
SELECT * 
from t1 where not EXISTS(
	SELECT * from t3 where t1.a=t3.a
)AND not EXISTS(
	SELECT * from t4 where t1.a=t4.a
);
/*插入只有t1和t4有的内容*/
insert into t2	(a,b,c,f)
SELECT t1.a,t1.b,t4.c,t4.f
from t1,t4 where not EXISTS(
	SELECT * from t3 where t1.a=t3.a
)and t1.a=t4.a;
/*插入只有t2有的内容*/
insert into t2	(a,c,d,e)
SELECT * 
from t3 where not EXISTS(
	SELECT * from t1 where t3.a=t1.a
)AND not EXISTS(
	SELECT * from t4 where t3.a=t4.a
);
/*插入只有t1,t3有的内容*/
insert into t2	(a,b,c,d,e)
SELECT t1.a,t1.b,t3.c,t3.d,t3.e
from t1,t3 where not EXISTS(
	SELECT * from t4 where t1.a=t4.a
)and t1.a=t3.a;
/*插入只有t4有的内容*/
insert into t2	(a,c,f)
SELECT * 
from t4 where not EXISTS(
	SELECT * from t1 where t4.a=t1.a
)AND not EXISTS(
	SELECT * from t3 where t4.a=t3.a
);
/*插入只有t3,t4有的内容*/
insert into t2	(a,c,d,e,f)
SELECT t3.a,t3.c,t3.d,t3.e,t4.f
from t4,t3 where not EXISTS(
	SELECT * from t1 where t1.a=t4.a
)and t4.a=t3.a;
/*插入都有的内容*/
insert into t2	(a,b,c,d,e,f)
SELECT t1.a,t1.b,t3.c,t3.d,t3.e,t4.f 
FROM t1,t3,t4 where t1.a=t3.a and t1.a=t4.a;


最后

t2


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值