회계 연도 매개 변수에 대해 2010 년, 2011 년 및 2012 년 옵션을 선택할 수 있지만 "제출 된 날짜"열에 2011 년 날짜가 여전히 표시됩니다. 예를 들어 2010 년을 선택하면 2010 년에 제출 된 데이터 만 보여 주어야하며 모든 연도 동안 똑같이 표시해야합니다. 어떤 도움이 필요합니까?동적 SQL을 사용하는 저장 프로 시저가 잘못된 데이터를 반환합니다.
set @sqlstr = '
Select
[SchoolName] As [School Name],
Status= CASE WHEN PS.PrivateSchoolID = Ed.PrivateSchoolID THEN ''Submitted''
ELSE ''Not Submitted''END,
[Submitted By]= CASE WHEN PS.PrivateSchoolID = Ed.PrivateSchoolID
THEN [FirstName] + '' '' + [LastName] ELSE NULL END,
[Submitted On]= CASE WHEN PS.PrivateSchoolID = Ed.PrivateSchoolID
THEN Convert(Varchar(10), Ed.CreatedDate, 101) ELSE NULL END
From EnrollmentDateSchool Ed Right Outer Join
(select FP.FiscalYear, PrivateSchool.* from PrivateSchool
INNER JOIN FiscalYearPrivateSchool FP
ON PrivateSchool.PrivateSchoolID = FP.PrivateSchoolID) PS
ON Ed.PrivateSchoolID = PS.PrivateSchoolID Left Outer Join
Finance.dbo.Person P ON Ed.CreatedBy = P.PersonID
Where (FiscalYear = '+convert(varchar, @FiscalYear)+') AND (PS.IsActive = 1)'
IF (@SchoolID != -1)
set @sqlstr = @sqlstr + ' AND SchoolID ='+ convert(varchar, @SchoolID)
IF (@Status = -1)
set @sqlstr = @sqlstr + ' AND (PS.PrivateSchoolID = PS.PrivateSchoolID' + ')'
ELSE IF (@Status = 1)
set @sqlstr = @sqlstr + ' AND (PS.PrivateSchoolID = Ed.PrivateSchoolID' + ')'
ELSE
set @sqlstr = @sqlstr + 'AND (Ed.PrivateSchoolID is null' + ')'
SET @sqlstr = @sqlstr + 'ORDER BY SchoolName'
EXEC(@sqlstr)
END
EXEC (@sqlstr) 대신'PRINT @sqlstr; '을 사용할 때 출력을 표시 할 수 있습니까? –
또한 길이가없는 CONVERT (VARCHAR,')를 사용하지 마십시오. 왜? http://sqlblog.com/blogs/aaron_bertrand/archive/2009/10/09/bad-habits-to-kick-declaring-varchar- without-length.aspx –