0


0

SQL Server 2008 R2で複数の異なるテーブルから単一のビューにレコードをプルするにはどうすればよいですか?

いくつかの異なるテーブル([Account]、[Branch]、[Customer]、[Employee]、[Transaction]、[FlaggedTrans])から値を取得するような、「サマリー」ビューのようなものを作成しようとしています。

ビューでは多数のSELECTステートメントを実行できないため、INNER JOINを使用してタスクを実行しようとしています。これが問題の原因です。

これが私のこれまでのところです。

CREATE VIEW Summary
AS
    SELECT NEWID() AS Summary_Id,
    COUNT(C.Customer_Id) AS CustCount,
    COUNT(A.Account_Id) AS AcctCount,
    COUNT(T.Transaction_Id) AS TransCount,
    COUNT(B.Branch_Id) AS BranchCount,
    COUNT(E.Employee_Id) AS EmplCount,
    CAST(SUM(A.Balance) AS INT) AS BalTotal,
    COUNT(F.FlaggedTrans_Id) AS FlagCount
    FROM dbo.Account A INNER JOIN
    dbo.Customer C ON A.Customer_Id = C.Customer_Id INNER JOIN
    dbo.Employee E ON A.Employee_Id = E.Employee_Id INNER JOIN
    dbo.[Transaction] T ON A.Account_Id = T.Account_Id INNER JOIN
    dbo.FlaggedTrans F ON E.Employee_Id = F.Employee_Id CROSS JOIN
    dbo.Branch B

論理的には十分に思えますが、すべての値がNULLまたは0に戻っています。 何がおかしいのですか?

3 回答


0


ビューを単一の選択が関連していない多数の選択として構築する場合は、UNION ALLを使用できます。


0


私はここで何が間違っているのか本当にわかりませんが、内部結合を1つずつ閉じて選択クエリを実行することをお勧めできます


0


まずCROSS JOINを削除し、必要に応じてWHERE句(WHERE My_ID IN(ブランチからIDを選択)など)に入れます。

また、テーブルを結合する必要はありませんが、別のオプションとして列として1つずつ選択します。 これはいくつかの擬似コードです:

SELECT
(SELECT COUNT(thisfield) FROM Thistable) as ThisCnt,
(SELECT COUNT(thatfield) FROM Thattable) as ThatCnt,
[etc.]