如何删除SQL-sever2000同一数据库下表名不同,而表中数据相同的两张表
在sql-sever2000中有一个数据库database名为wordtest,里面有多张表A、B、C、D等,这些表都只有一个字段,有以下两个问题要问:1、如何判断多个表...
在sql-sever2000中有一个数据库database名为wordtest,里面有多张表A、B、C、D等,这些表都只有一个字段,有以下两个问题要问:
1、如何判断多个表中值是否相同,相同如何删掉?比如A、B两表虽然表名不同,但里面字段值是相同的,如何删掉其中一个?
2、如果A、B、C、D有重复值,如何删掉,比如A包含部分C的值,如何在C中查找出并删掉?
3、如何把这几个表合并成一个大表,并且里面没有重复值?
希望懂得朋友能帮忙,多谢! 展开
1、如何判断多个表中值是否相同,相同如何删掉?比如A、B两表虽然表名不同,但里面字段值是相同的,如何删掉其中一个?
2、如果A、B、C、D有重复值,如何删掉,比如A包含部分C的值,如何在C中查找出并删掉?
3、如何把这几个表合并成一个大表,并且里面没有重复值?
希望懂得朋友能帮忙,多谢! 展开
3个回答
展开全部
假设table A,B,C,D 的列名都是C1
1、删掉B表中的和A表的重复值 DELETE B WHERE B.C1 IN(SELECT A.C1 FROM A);
2、删掉C表中的和A表的重复值:DELETE c WHEREc.c1 in(SELECT a.c1 FROM a);
3、方法1 :分三次执行
insert into a select * from b where b.c1 not in(select a.c1 from a);
insert into a select * from c where c.c1 not in(select a.c1 from a);
insert into a select * from d where d.c1 not in(select a.c1 from a);
方法2: 一次性
with list1 as
(
select distinct c1 from
(
select c1 from b
union
select c1 from c
union
select c1 from d )
)
inset into a.c1 select list1.c1 from list1 where list1.c1 not in (select a.c1 from a);
???是不是这样写,sqlserver有点忘了,oracle用多了
1、删掉B表中的和A表的重复值 DELETE B WHERE B.C1 IN(SELECT A.C1 FROM A);
2、删掉C表中的和A表的重复值:DELETE c WHEREc.c1 in(SELECT a.c1 FROM a);
3、方法1 :分三次执行
insert into a select * from b where b.c1 not in(select a.c1 from a);
insert into a select * from c where c.c1 not in(select a.c1 from a);
insert into a select * from d where d.c1 not in(select a.c1 from a);
方法2: 一次性
with list1 as
(
select distinct c1 from
(
select c1 from b
union
select c1 from c
union
select c1 from d )
)
inset into a.c1 select list1.c1 from list1 where list1.c1 not in (select a.c1 from a);
???是不是这样写,sqlserver有点忘了,oracle用多了
追问
你好,关于问题2,不是要删掉表C而是在C中删掉A与C的交集。
比如表A中有字段name 里面有三个值:张三,李四,王武
表B中同样字段有两个值李四,张九,
要求的操作是将B中李四删掉,留下张九,请问如何操作?多谢!
追答
delete B where B.name in(select A.name from A);
展开全部
DELETE FROM A WHERE ID IN (SELECT A.ID FROM A WHERE ID NOT IN(SELECT B.ID FROM B))
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
用到两个限定语句:IF NOT EXIST和DISTINCT。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询