以前に変数値をサブクエリに渡そうとしたことがなく、間違っているようです。エラーは発生していませんが、結果も得られませんが、開始日、終了日、役割の値をサブクエリにハードコードすると、正しく実行されます。
================編集 =======================
残念ながら、私が遊んでいた以前のテスト スクリプトを投稿しましたが、実際にはエラーでいっぱいでした。申し訳ありません。これが私が作業している実際のコードです。
DECLARE @Role varchar,
@StartDate datetime,
@Enddate datetime;
SET @Role = 'Volunteer';
SET @StartDate = DATEADD(d, -100, getdate());
SET @Enddate = getdate();
SELECT rolename, Category, [1] as [1 Day],[2] as [2 Days],[3] as [3 Days],[4] as [4 Days],[5] as [5 Days],[6] as [6 Days],[7] as [7 Days] FROM
(SELECT CriminalHistoryID, vps.RoleName, 'Rec2PreClr' as Category,
DATEDIFF(d, chc.ReceiveDate, chc.PreClrDate) as DaysDif
FROM dbo.v_PersonStatus vps
INNER JOIN dbo.CriminalHistoryCheck chc
ON vps.PersonID = chc.PersonID
WHERE chc.ReceiveDate BETWEEN @StartDate AND @Enddate AND vps.rolename = @Role and DATEDIFF(d, chc.ReceiveDate, chc.PreClrDate) BETWEEN 0 and 7
UNION
SELECT CriminalHistoryID, vps.RoleName, 'PreClr2Clr' as Category,
DATEDIFF(d, chc.PreClrDate, chc.FinalDate) as DaysDif
FROM dbo.v_PersonStatus vps
INNER JOIN dbo.CriminalHistoryCheck chc
ON vps.PersonID = chc.PersonID
WHERE chc.ReceiveDate BETWEEN @StartDate AND @Enddate AND vps.rolename = @Role AND DATEDIFF(d, chc.PreClrDate, chc.FinalDate) BETWEEN 0 and 7
UNION
SELECT CriminalHistoryID, vps.RoleName, 'Rec2Clr' as Category,
DATEDIFF(d, chc.ReceiveDate, FinalDate) as DaysDif
FROM dbo.v_PersonStatus vps
INNER JOIN dbo.CriminalHistoryCheck chc
ON vps.PersonID = chc.PersonID
WHERE chc.ReceiveDate BETWEEN @StartDate AND @Enddate AND vps.rolename = @Role AND DATEDIFF(d, chc.ReceiveDate, FinalDate) BETWEEN 0 and 7
) UNIONqry
PIVOT
(count(CriminalHistoryID) for DaysDif in ([1],[2],[3],[4],[5],[6],[7])) pvt
Order by RoleName, Category
@Startdate、@Enddate、および @Role の値がサブクエリに入っていないようです。サブにボックスの外を見るように指示するために何かをする必要がありますか?