1

SQL Server 2005 で実行中 2 つのクエリで少し問題が発生しました。1 つ目は、次のようなテーブルを返します。

名前 PastDUe DueTomorr 期限は今日 期限は月曜日 期限はそれ以降
クライアント 23 10 8 13 32

そして2番目は、Excelのピボットテーブルで実行すると同じテーブル/データに加算されないという同じ情報のリストを返します。ビジュアルスタジオのプロジェクトの2つの異なるデータソース/目的でこれらを使用しているため、1つだけを使用することはできません. 何がうまくいかないのかわかりませんが、さまざまな方法で結果を計算しているので、数学がずれているのか、そのようなものなのかわかりません。このデータは日々正確である必要があるため、これは非常に重要です。dbo.TruncateDate が何をしているのか疑問に思われる場合は、システム内の注文の ordernumber を参照し、日付を含む何かを実行すると、すべてを含むシステム内のテーブルに基づいて、クエリの一部がすべての週末と休日を確実に無視するようになります。これらの日付の。それが理にかなっていることを願っています。もっと情報を提供できるかどうか教えてください。

クエリ 1:

with cte AS (SELECT cl.Name,    
     SUM(CASE WHEN CURRENT_TIMESTAMP > oi.RequiredByDate THEN 1 ELSE 0 END) as PastDue
    ,SUM(CASE WHEN DATEADD(dd, DATEDIFF(dd, 0, oi.RequiredByDate), 0) = dateadd(day, datediff(day, '19000101',CURRENT_TIMESTAMP),'19000102') then 1 ELSE 0 END) as DueTomorrow
    ,SUM(CASE WHEN dbo.TruncateDate(CURRENT_TIMESTAMP) = dbo.TruncateDate(oi.RequiredByDate) THEN 1 Else 0 END) as DueToday
    ,SUM(CASE WHEN DateDiff(day, getdate(), RequiredByDate) BETWEEN 2 and 7 AND DateName(weekday, RequiredByDate) = 'Monday' Then 1 ELSE 0 END) as DueMonday
    ,SUM(CASE WHEN DATEADD(DAY, 2,dbo.TruncateDate(CURRENT_TIMESTAMP)) <=       dbo.TruncateDate(oi.RequiredByDate) THEN 1 ELSE 0 END) as DueBeyond  

     FROM OrderItems oi
     JOIN Orders o ON o.OrderID = oi.OrderID
     JOIN Counties c ON c.FIPS = o.FIPS
     JOIN Clients cl ON cl.ClientID = o.ClientID
     JOIN Milestones m ON m.MilestoneID = oi.LastMilestoneID
     JOIN Products p ON p.ProductID = oi.ProductID
     JOIN Vendors v ON v.VendorID = oi.VendorID
     LEFT JOIN ClientBranches clb ON clb.ClientID = o.ClientID
     WHERE QueueID > 0 AND cl.Name NOT LIKE 'TES%'
     AND cl.NAME LIKE 'HLC%'
     GROUP BY cl.Name)

     Select * FROM cte 

クエリ 2:

SELECT cl.Name as Client, clb.Name as ClientBranch
  ,
CASE 
    WHEN CURRENT_TIMESTAMP > oi.RequiredByDate THEN 'Past Due'
    WHEN dbo.TruncateDate(CURRENT_TIMESTAMP) = dbo.TruncateDate    (oi.RequiredByDate) THEN 'Due Today'
    WHEN DATEADD(dd, DATEDIFF(dd, 0, oi.RequiredByDate), 0) = dateadd(day, datediff(day, '19000101',CURRENT_TIMESTAMP),'19000102') then 'Due Tomorrow'
    WHEN DateDiff(day, getdate(), RequiredByDate) BETWEEN 2 and 7 AND DateName(weekday, RequiredByDate) = 'Monday' Then 'Due Monday'
    WHEN DATEADD(DAY, 2,dbo.TruncateDate(CURRENT_TIMESTAMP)) <= dbo.TruncateDate(oi.RequiredByDate) THEN 'Due Beyond'  
    ELSE 'WRONG' end
    as DeliveryStatus

 FROM OrderItems oi
 JOIN Orders o ON o.OrderID = oi.OrderID
 JOIN Counties c ON c.FIPS = o.FIPS
 JOIN Clients cl ON cl.ClientID = o.ClientID
 JOIN Milestones m ON m.MilestoneID = oi.LastMilestoneID
 JOIN Products p ON p.ProductID = oi.ProductID
 JOIN Vendors v ON v.VendorID = oi.VendorID
 LEFT JOIN ClientBranches clb ON clb.ClientID = o.ClientID


 WHERE QueueID > 0
and cl.Name not like ('Tes%')
and cl.Name Like 'HLC%'
4

1 に答える 1

1

これを実行してください:

with cte AS (SELECT cl.Name,    
     SUM(CASE WHEN CURRENT_TIMESTAMP > oi.RequiredByDate THEN 1 ELSE 0 END) as PastDue
    ,SUM(CASE WHEN DATEADD(dd, DATEDIFF(dd, 0, oi.RequiredByDate), 0) = dateadd(day, datediff(day, '19000101',CURRENT_TIMESTAMP),'19000102') then 1 ELSE 0 END) as DueTomorrow
    ,SUM(CASE WHEN dbo.TruncateDate(CURRENT_TIMESTAMP) = dbo.TruncateDate(oi.RequiredByDate) THEN 1 Else 0 END) as DueToday
    ,SUM(CASE WHEN DateDiff(day, getdate(), RequiredByDate) BETWEEN 2 and 7 AND DateName(weekday, RequiredByDate) = 'Monday' Then 1 ELSE 0 END) as DueMonday
    ,SUM(CASE WHEN DATEADD(DAY, 2,dbo.TruncateDate(CURRENT_TIMESTAMP)) <=       dbo.TruncateDate(oi.RequiredByDate) THEN 1 ELSE 0 END) as DueBeyond,
     COUNT(*) AS cnt

     FROM OrderItems oi
     JOIN Orders o ON o.OrderID = oi.OrderID
     JOIN Counties c ON c.FIPS = o.FIPS
     JOIN Clients cl ON cl.ClientID = o.ClientID
     JOIN Milestones m ON m.MilestoneID = oi.LastMilestoneID
     JOIN Products p ON p.ProductID = oi.ProductID
     JOIN Vendors v ON v.VendorID = oi.VendorID
     LEFT JOIN ClientBranches clb ON clb.ClientID = o.ClientID
     WHERE QueueID > 0 AND cl.Name NOT LIKE 'TES%'
     AND cl.NAME LIKE 'HLC%'
     GROUP BY cl.Name)

cnt他のすべてのフィールドの合計と等しいことを確認しますか?

アップデート:

これを実行してください

SELECT  *
FROM    (
SELECT cl.Name,    
    CASE WHEN CURRENT_TIMESTAMP > oi.RequiredByDate THEN 1 ELSE 0 END as PastDue,
    CASE WHEN DATEADD(dd, DATEDIFF(dd, 0, oi.RequiredByDate), 0) = dateadd(day, datediff(day, '19000101',CURRENT_TIMESTAMP),'19000102') then 1 ELSE 0 END as DueTomorrow,
    CASE WHEN dbo.TruncateDate(CURRENT_TIMESTAMP) = dbo.TruncateDate(oi.RequiredByDate) THEN 1 Else 0 END as DueToday,
    CASE WHEN DateDiff(day, getdate(), RequiredByDate) BETWEEN 2 and 7 AND DateName(weekday, RequiredByDate) = 'Monday' Then 1 ELSE 0 END as DueMonday,
    CASE WHEN DATEADD(DAY, 2,dbo.TruncateDate(CURRENT_TIMESTAMP)) <=       dbo.TruncateDate(oi.RequiredByDate) THEN 1 ELSE 0 END as DueBeyond,
     FROM OrderItems oi
     JOIN Orders o ON o.OrderID = oi.OrderID
     JOIN Counties c ON c.FIPS = o.FIPS
     JOIN Clients cl ON cl.ClientID = o.ClientID
     JOIN Milestones m ON m.MilestoneID = oi.LastMilestoneID
     JOIN Products p ON p.ProductID = oi.ProductID
     JOIN Vendors v ON v.VendorID = oi.VendorID
     LEFT JOIN ClientBranches clb ON clb.ClientID = o.ClientID
     WHERE QueueID > 0 AND cl.Name NOT LIKE 'TES%'
     AND cl.NAME LIKE 'HLC%'
     ) q
  WHERE PastDue + DueTomorrow + DueToday + DueMonday + DueBeyond > 1

複数回カウントされたレコードを表示します。

于 2012-04-19T14:59:58.863 に答える