用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 是后来加上去的,加上去后,就查出了重复数据,谁可以帮我看看 展开
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 是后来加上去的,加上去后,就查出了重复数据,谁可以帮我看看 展开
13个回答
展开全部
LEFT JOIN 关键字会从左表 (表1) 那里返回所有的行,即使在右表 (c,d) 中没有匹配的行。
也就是表1的记录数少于c,d表的记录数
那么表1就重复一些记录和c,d一样多。
也就是表1的记录数少于c,d表的记录数
那么表1就重复一些记录和c,d一样多。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这说明你的表,存在着一对多的关系 或者 关系不明确,导致了这样的结果,
你必须把表结构和数据帖出来,并把你希望得到的结果写出来
这样别人才有办法帮助你
你必须把表结构和数据帖出来,并把你希望得到的结果写出来
这样别人才有办法帮助你
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你这样写
select * from table1,table2,table3
where
table1.column1=table2.column1
and table1.column1=table3.column1
你可以试试 我做3张表的时候基本思路是这样的
可能有些细节问题...
select * from table1,table2,table3
where
table1.column1=table2.column1
and table1.column1=table3.column1
你可以试试 我做3张表的时候基本思路是这样的
可能有些细节问题...
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你是把所有字段都查询出来了吗?如果没有,就估计是表8或表9 中还有字段需要一起查询出来,才不会出现重复记录
-----------------------------------------------
你的sql里表T_GatheringInvoice和倒数第二个left join 里的表T_InvoiceOrder的别名都一样是b了,这两个表又有相同字段,肯定有问题!
-----------------------------------------------
你的sql里表T_GatheringInvoice和倒数第二个left join 里的表T_InvoiceOrder的别名都一样是b了,这两个表又有相同字段,肯定有问题!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询