【发布时间】:2012-04-03 21:51:37
【问题描述】:
使用 Microsoft SQL Server 2008 我有一个需要注意的查询。 我对正确执行查询所需的连接感到困惑。
USE [ShaftData]
GO
/****** Object: StoredProcedure [dbo].[MyPareto] Script Date: 04/03/2012 19:32:31 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER PROCEDURE [dbo].[MyPareto]
as
SELECT i.pg,
dbo.OldParetoAnalysis.Pareto,
i.part,
i.sumofqty,
a.sumofqty,
dbo.NewParetoAnalysis.Pareto
FROM
OPENQUERY(SACBAUTO, 'SELECT dbo.iLines.Part,
dbo.iLines.Pg,
SUM(dbo.iLines.Qty) as sumofqty,
dbo.iLines.Prefix
FROM Autopart.dbo.iLines
where prefix = ''i''
and [datetime] > dateadd(month, -6, getdate())
group by
dbo.ilines.pg,
dbo.ilines.part,
dbo.ilines.prefix
order by sumofqty desc') i
RIGHT JOIN
dbo.OldParetoAnalysis
on
i.part collate SQL_Latin1_General_CP1_CI_AS = dbo.OldParetoAnalysis.Part
LEFT JOIN
OPENQUERY(SACBAUTO, 'SELECT dbo.aLines.Part,
dbo.aLines.Pg,
SUM(dbo.aLines.Qty) as sumofqty,
dbo.aLines.Prefix
FROM Autopart.dbo.aLines
where prefix = ''d''
and [datetime] > dateadd(month, -6, getdate())
group by
dbo.alines.pg,
dbo.alines.part,
dbo.alines.prefix
order by sumofqty desc') a
ON
dbo.OldParetoAnalysis.Part collate SQL_Latin1_General_CP1_CI_AS = a.part
FULL JOIN
dbo.NewParetoAnalysis
ON
a.part collate SQL_Latin1_General_CP1_CI_AS = dbo.NewParetoAnalysis.Part
WHERE
i.pg = '31'
GROUP BY
i.pg,
dbo.OldParetoAnalysis.Pareto,
i.part,
i.sumofqty,
a.sumofqty,
dbo.NewParetoAnalysis.Pareto
ORDER BY
dbo.OldParetoAnalysis.Pareto desc
好的解释,我需要显示这些字段。目前我需要显示旧帕累托的所有行。新的帕累托是旧帕累托的克隆,将用于更新(这是计划的下一部分)。
问题是目前我的帕累托显示正确 1-5780。但是应该逐行匹配的新帕累托列显示空白,这表明并非所有行都显示(可能与空值有关)。
我希望它与我的联接有关,因为您可以看到它可能是一个过于复杂的查询,但它可以满足我的需要,问题是时间,它很匆忙,因为我有 24 小时来完成这个查询而没有事先计划(是的,我也面临着手掌)。
哦,帕累托只是分配给最畅销部分的数字,例如联赛。
如果您需要更多信息,请询问并进行编辑。
非常感谢
编辑: 好的解决了问题,答案会更新。
我很困惑,谁能告诉我现在如何更新我的新旧帕累托表?因为有大量的连接
【问题讨论】:
-
哎呀...也许考虑将
OPENQUERY更改为引用您的链接服务器的视图?这可能会大大简化您的查询,让您更容易理解。 -
是的,在我去抽烟之后,我终于破解了这个吸盘。要求我更改查询和连接的布局。如果有人感兴趣,我会发布编辑后的版本
-
如果您还有问题,我会更新您的问题。如果您更新后的查询解决了您的问题,我会将其发布为您自己问题的答案,然后将其标记为已接受的答案。
-
只要确保将其作为答案发布即可。不要编辑你原来的问题,好吗?
-
是的,只是还做不到 :( 没想到我能破解它。但有片刻的清晰,尼古丁能做什么,哈哈。
标签: sql sql-server sql-server-2008 join