SQL SERVER 两个表联合查询导入一张空表时,数据重复问题。难点,求解答

createtablea(a1int,a2Varchar(30),a3int)insertaselect1,'a1',1unionallselect1,'a2',1uni... create table a(a1 int,a2 Varchar(30),a3 int)
insert a
select 1 ,'a1' ,1 union all
select 1 ,'a2' ,1 union all
select 1 ,'a3' ,1 union all
select 2 ,'a4' ,2 union all
select 2 ,'a5' ,2 union all
select 2 ,'a6' ,2 union all
select 3 ,'a7' ,3 union all
select 3 ,'a8' ,3 union all
select 3 ,'a9',3

create table b(b1 int,b2 Varchar(30),b3 int)
insert b
select 1 ,'b1' ,1 union all
select 1 ,'b2',1 union all
select 1 ,'b3' ,1 union all
select 3 ,'b4' ,3 union all
select 3 ,'b5' ,3 union all
select 3 ,'b6' ,3

想得到的C为:
a1 b1 1
a2 b2 1
a3 b3 1
a7 b4 3
a8 b5 3
a9 b6 3
或者
a2 b2 1
a3 b1 1
a1 b3 1
a7 b6 3
a8 b4 3
a9 b5 3
等 只要不重复就行....
展开
 我来答
南方行走5m
2011-07-19 · 超过12用户采纳过TA的回答
知道答主
回答量:24
采纳率:0%
帮助的人:38.5万
展开全部
先分组排名,在连接查询
select ta.a2,tb.b2,ta.a1
(select a1,a2, row_number() over(PARTITION BY ORDER by field1) as 序号 from a) ta,
(select b1,b2, row_number() over(PARTITION BY ORDER by field1) as 序号 from b) tb
where ta.a1 = tb.b1 and ta.序号 = tb.序号
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
乙克洋
2011-07-23
知道答主
回答量:21
采纳率:0%
帮助的人:0
展开全部
select a.a2,b.b2,b.b3 from a a join b b on a.a1 = b.b1
即可得到如下结果
a1 b1 1
a2 b1 1
a3 b1 1
a1 b2 1
a2 b2 1
a3 b2 1
a1 b3 1
a2 b3 1
a3 b3 1
a7 b4 3
a8 b4 3
a9 b4 3
a7 b5 3
a8 b5 3
a9 b5 3
a7 b6 3
a8 b6 3
a9 b6 3
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
是小白啊2k
2011-07-19 · TA获得超过2566个赞
知道小有建树答主
回答量:1183
采纳率:0%
帮助的人:1161万
展开全部
select a2,b2,a3 from a
inner join b on a.a1=b.b1
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式