
用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个回答
展开全部
写多一层
select distinct(XX)
from
(
--括号里填你的查询语句:
select ……from ……
left join 表8 as c on c.字段1 = 表1.字段1
left join 表9 as d on d.字段1=c.字段1
) as tb
select distinct(XX)
from
(
--括号里填你的查询语句:
select ……from ……
left join 表8 as c on c.字段1 = 表1.字段1
left join 表9 as d on d.字段1=c.字段1
) as tb
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
看看 表8 和 表9 是否有字段1相同的值 。 左右连接都不会增加的
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你是把所有字段都查询出来了吗?如果没有,就估计是表8或表9 中还有字段需要一起查询出来,才不会出现重复记录.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
参照这个去执行 读出重复数据
SELECT * FROM (SELECT CLOUM_NAME,ROW_NUMBER() OVER(PARTITION BY COLNUM_NAME ORDER BY COLNUM_NAME) NUM FROM TABLE_NAME) T
WHERE T.NUM>=1
SELECT * FROM (SELECT CLOUM_NAME,ROW_NUMBER() OVER(PARTITION BY COLNUM_NAME ORDER BY COLNUM_NAME) NUM FROM TABLE_NAME) T
WHERE T.NUM>=1
参考资料: em_pass
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
用sql语句进行多表连接查询,去除重数据:
1、利用distinct
2、利用group by
1、利用distinct
2、利用group by
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询