如Alex K所述,您应该将其编写为内联表值函数。这是描述它的文章。
简而言之,语法将类似于
CREATE FUNCTION dbo.GetForPeriod
( @StartDate datetime, @EndDate datetime)
RETURNS TABLE
RETURN
SELECT [[ your column list ]]
FROM [[ table list]
WHERE [[some column] BETWEEN @StartDate AND @EndDate
您可以有一个选择查询(但是很复杂,可以使用CTE)。然后您将其用作
SELECT * FROM dbo.GetForPeriod('1-Jan-2010', '31-Jan-2010')