簡単な手順を書くのに助けが必要です。私がやろうとしていることを説明させてください。
私は3つのテーブルを持っています
- tJobOffer
- tApplication
- tApplicationStatus
このtJobOfferのさまざまなステータスの統計を含むtJobOfferのリストを返すプロシージャを作成したいと思います。tApplicationStatusは、tJobOfferにリンクされているtApplicationにリンクされています。アプリケーションは、CANDIDATE / ACCEPTED / REFUSED / IGNORED/..にすることができます。
私はこのクエリを作成しました:
SELECT
[T].[JobOfferId],
[T].[JobOfferTitle],
COUNT([A].[ApplicationId]) AS [CandidateCount]
FROM [tJobOffer] AS [T]
LEFT JOIN [tApplication] AS [A]
INNER JOIN [tApplicationStatus] AS [S]
ON [S].[ApplicationStatusId] = [A].[ApplicationStatusId]
AND [S].[ApplicationStatusTechnicalName] = 'CANDIDATE'
ON [A].[JobOfferId] = [T].[JobOfferId]
GROUP BY
[T].[JobOfferId],
[T].[JobOfferTitle]
ORDER BY [T].[JobOfferTitle] ;
結果は
> 52ED7C67-21E1-49BB-A1F8-0601E6EED1EA Announce a 0
> F26B228D-0C81-4DA8-A287-F8F997CC1F9C Announce b 0
> 9DA60B23-F113-4C7F-9707-2B90C1556D5D Announce c 2
> 258E11A7-79C1-47B6-8C61-413AA54E2360 Announce d 0
> DA582383-5DF4-4E1D-837C-382371BDEF57 Announce e 1
結果は正しいです。ステータス候補の統計を含むtJoboffersを取得します。アナウンスcの候補者が2人、アナウンスeの候補者が1人います。文字列「CANDIDATE」を「ACCEPTED」または「REFUSED」に変更すると、これらのステータスの統計を取得できます。1回のリクエストですべてを取得することは可能ですか?
何かのようなもの
> 52ED7C67-21E1-49BB-A1F8-0601E6EED1EA Announce a 0 0 2
> F26B228D-0C81-4DA8-A287-F8F997CC1F9C Announce b 0 0 1
> 9DA60B23-F113-4C7F-9707-2B90C1556D5D Announce c 2 0 0
> 258E11A7-79C1-47B6-8C61-413AA54E2360 Announce d 0 0 0
> DA582383-5DF4-4E1D-837C-382371BDEF57 Announce e 1 1 0