用sql语句进行多表连接查询,怎么不查出重复数据

现在呢,我有7张表,基本上每张表都与主表有关联,这里我们假设主表为表1,其他的分别为表2,表3,表4,表5,表6,表7,他们使用连接查询的时候没有查出重复数据,但现在呢,... 现在呢,我有7张表,基本上每张表都与主表有关联,这里我们假设主表为表1,其他的分别为表2,表3,表4,表5,表6,表7,他们使用连接查询的时候没有查出重复数据,但现在呢,我加了两个表连接,
left join 表8 as c on c.字段1 = 表1.字段1
left join 表9 as d on d.字段1=c.字段1
结果呢,我就查出了重复数据

如果有哪位仁兄呢,答的答案我可以接受,我会把我的表结构告诉你,同时我的财富值也会不吝啬的多给的哦
select top 500 A.*,0 gatheringAmount,d.FOrderID FSalesOrderID,d.FCode FSalesOrderCode,
isNull(q.FName,'') FContactName, isNull(q.FOfficePhone,'') FContactPhone
from V_Invoice A
inner join T_GatheringInvoice b ON a.FInvoiceID=b.FInvoiceID
left join T_InvoiceOrder c ON b.FinvoiceID = c.FinvoiceID and b.FSalesOrderID = c.FOrderID
left join T_SalesOrder d on d.FOrderID = b.FSalesOrderID
left join CRM_Contacts q ON A.FContactID = q.FContactID
left join T_InvoiceOrder b on a.FInvoiceID = b.FInvoiceID
left join T_SalesOrder y on b.FOrderID = y.FOrderID
where 1=1 Order By A.FCreateDate

后面的两个left join 是后来加上去的,加上去后,就查出了重复数据,谁可以帮我看看
展开
 我来答
vvxbu24
推荐于2018-04-11 · TA获得超过315个赞
知道答主
回答量:231
采纳率:0%
帮助的人:0
展开全部
SELECT T1.name,T1.buyAmount,T2.sellAmount FROM
(SELECT A.name,SUM(buyAmount) FROM A GROUP BY A.name) T1
LEFT JOIN
(SELECT B.name,SUM(sellAmount) FROM B GROUP BY B.name) T2
ON T1.name=T2.name

答案应该是这样子。先统计后联接
百度网友bd0325f
2011-02-15 · TA获得超过373个赞
知道小有建树答主
回答量:298
采纳率:0%
帮助的人:196万
展开全部
LEFT JOIN 关键字会从左表 (表1) 那里返回所有的行,即使在右表 (c,d) 中没有匹配的行。
也就是表1的记录数少于c,d表的记录数
那么表1就重复一些记录和c,d一样多。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
ThinkIBM
2011-02-15 · TA获得超过5289个赞
知道大有可为答主
回答量:3263
采纳率:0%
帮助的人:5449万
展开全部
这说明你的表,存在着一对多的关系 或者 关系不明确,导致了这样的结果,
你必须把表结构和数据帖出来,并把你希望得到的结果写出来

这样别人才有办法帮助你
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
printf59277
2011-02-15 · TA获得超过1080个赞
知道大有可为答主
回答量:1812
采纳率:33%
帮助的人:1275万
展开全部
你这样写
select * from table1,table2,table3
where
table1.column1=table2.column1
and table1.column1=table3.column1
你可以试试 我做3张表的时候基本思路是这样的
可能有些细节问题...
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
wind12355
2011-02-17
知道答主
回答量:17
采纳率:0%
帮助的人:0
展开全部
你是把所有字段都查询出来了吗?如果没有,就估计是表8或表9 中还有字段需要一起查询出来,才不会出现重复记录
-----------------------------------------------
你的sql里表T_GatheringInvoice和倒数第二个left join 里的表T_InvoiceOrder的别名都一样是b了,这两个表又有相同字段,肯定有问题!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(11)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式