0

特定の基準でいくつかのテーブルに参加しています。結合から除外されたレコードの数も表示できるかどうかを知りたいですか?

私の質問:

SELECT...

FROM         dbo.QuickLabDump 
             ...

             left outer join hermes.lom.dbo.lom_specimen Lom
              on QuickLabDump.[specimen id] = lom.specimen
              LEFT outer join SalesDWH.dbo.Isomers Isomers
              on QuickLabDump.[specimen id] = Isomers.[accession id]



WHERE     lom.specimen is null
              and isomers.[accession id] is null...

ご覧のとおり、左外部結合が 2 つあります。

このクエリの結果に加えて、除外されたhermes.lom.dbo.lom_specimenレコードの数も返したいと思います。SalesDWH.dbo.Isomers

除外されたフィールドの数を取得するにはどうすればよいですか?

完全なクエリは次のとおりです。

USE [SalesDWH]
GO

/****** Object:  View [dbo].[TurnAround]    Script Date: 07/10/2012 20:46:40 ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO






ALTER VIEW [dbo].[TurnAround]
AS
SELECT     dbo.QuickLabDump.[Specimen ID], DATEPART(yyyy, dbo.QuickLabDump.[Date Entered]) AS [Year Entered],
DATEPART(yyyy, dbo.QuickLabDump.[Date Completed]) AS [year completed],

 CAST(CAST(dbo.QuickLabDump.[Date Entered] AS DATE) 
                      AS DATETIME) + CAST(dbo.QuickLabDump.[Time Entered] AS TIME) AS [DateTime Entered], CAST(CAST(dbo.QuickLabDump.[Date Completed] AS DATE) AS DATETIME) 
                      + CAST(dbo.QuickLabDump.[Time Completed] AS TIME) AS [DateTime Completed], dbo.QuickLabDump.[Practice Code] AS [QL Practuce Code], 
                      dbo.QLMLISMapping.[MLIS Practice ID], DATEPART(m, dbo.QuickLabDump.[Date Entered]) AS [Month Entered], 
                      DATEPART(m, dbo.QuickLabDump.[Date Completed]) AS [Month Completed],
                      ROUND(CAST(DATEDIFF(mi, 
                      CAST(CAST(dbo.QuickLabDump.[Date Entered] AS DATE) AS DATETIME) + CAST(dbo.QuickLabDump.[Time Entered] AS TIME), 
                      CAST(CAST(dbo.QuickLabDump.[Date Completed] AS DATE) AS DATETIME) + CAST(dbo.QuickLabDump.[Time Completed] AS TIME)) AS FLOAT) / 60, 0) AS TAT, 
                      ROUND(CAST(DATEDIFF(mi, CAST(CAST(dbo.QuickLabDump.[Date Entered] AS DATE) AS DATETIME) + CAST('9:00AM' AS TIME), 


                      CAST(CAST(dbo.QuickLabDump.[Date Completed] AS DATE) AS DATETIME) 
                      + CAST(dbo.QuickLabDump.[Time Completed] AS TIME)) AS float) / 60, 0) 

                      AS [Hours TurnAround Since 9AM], TAT9AMStateAdjusted=                   



                      ROUND(CAST(DATEDIFF(mi, CAST(CAST(dbo.QuickLabDump.[Date Entered] AS DATE) AS DATETIME) 
                      + CAST('9:00AM' AS TIME),                                            
                      CAST(CAST(dbo.QuickLabDump.[Date Completed] AS DATE) AS DATETIME) 
                      + CAST(dbo.QuickLabDump.[Time Completed] AS TIME)) AS float) / 60, 0)                         


                      +dbo.adjustedtime.timedifference
                      ,dbo.QuickLabDump.[Order Count], CONVERT(VARCHAR(8), DATEADD(D, - (1 * DATEPART(dw, dbo.QuickLabDump.[Date Entered])) + 6,
                       dbo.QuickLabDump.[Date Entered]), 1) AS [Week Ending]
FROM         dbo.QuickLabDump 
             INNER JOIN dbo.QLMLISMapping 
             ON dbo.QuickLabDump.[Practice Code] = dbo.QLMLISMapping.[Quicklab ID]
             left outer join dbo.AccountState
             on dbo.QuickLabDump.[Practice Code]=dbo.AccountState.[Account]
             left outer join dbo.AdjustedTime 
             ON dbo.AccountState.[state]=dbo.adjustedtime.[state]

             left outer join hermes.lom.dbo.lom_specimen Lom
              on QuickLabDump.[specimen id] = lom.specimen
              LEFT outer join SalesDWH.dbo.Isomers Isomers
              on QuickLabDump.[specimen id] = Isomers.[accession id]



WHERE     lom.specimen is null
              and isomers.[accession id] is null

              and (dbo.QuickLabDump.[Practice Code] NOT LIKE 'test%') 
              AND (dbo.QuickLabDump.[Specimen ID] NOT LIKE 'of%') 
              AND (dbo.QuickLabDump.Outcome <> 'rejected')
GROUP BY dbo.QuickLabDump.[Specimen ID], dbo.QuickLabDump.[Date Entered], dbo.QuickLabDump.[Time Entered], dbo.QuickLabDump.[Date Completed], 
                      dbo.QuickLabDump.[Time Completed], dbo.QuickLabDump.[Practice Name], dbo.QuickLabDump.[Practice Code], dbo.QuickLabDump.[Order Count], 
                      dbo.QLMLISMapping.[MLIS Practice ID],dbo.adjustedtime.timedifference
HAVING      (dbo.QuickLabDump.[Order Count] = MAX(dbo.QuickLabDump.[Order Count])) OR
                      (dbo.QuickLabDump.[Order Count] IS NULL)






GO
4

2 に答える 2

1

これをお探しですか?

SELECT      ...,
            (
              SELECT COUNt(*) FROM hermes.lom.dbo.lom_specimen WHERE specimen = lom.specimen
             ) AS ColCount

FROM         dbo.QuickLabDump    
             left outer join hermes.lom.dbo.lom_specimen Lom   
              on QuickLabDump.[specimen id] = lom.specimen   
              LEFT outer join SalesDWH.dbo.Isomers Isomers   
              on QuickLabDump.[specimen id] = Isomers.[accession id]   
WHERE     lom.specimen is null   
              and isomers.[accession id] is null
于 2012-07-11T04:25:06.750 に答える
1

WHERE句を指定せずに同じクエリを実行し、FULL OUTER JOINを使用すると、選択可能なユニバースのすべての行が得られます。

于 2012-07-11T04:25:36.660 に答える