Попробуйте это:
CREATE PROCEDURE usp_GetCourseSummary
@Course nvarchar(100)
AS
SET NOCOUNT ON;
SELECT
COUNT(StudentId) AS [Total Students],
SUM(CASE WHEN CourseStatus = 'Pass' THEN 1 ELSE 0 END) AS [Total Pass],
SUM(CASE WHEN CourseStatus = 'Pass' THEN 1 ELSE 0 END) * 100 / COUNT(*) AS [% Pass],
SUM(CASE WHEN CourseStatus = 'Fail' THEN 1 ELSE 0 END) AS [Total Fail],
SUM(CASE WHEN CourseStatus = 'Fail' THEN 1 ELSE 0 END) * 100 / COUNT(*) AS [% Fail]
FROM table1
WHERE Course = @Course;
GO
EXEC usp_GetCourseSummary 'Math'
Результат:
Total Students Total Pass % Pass Total Fail % Fail
2 1 50 1 50
Данные испытаний:
CREATE TABLE Table1 (StudentID INT NOT NULL, Course NVARCHAR(100) NOT NULL, CourseStatus NVARCHAR(100) NOT NULL);
INSERT INTO Table1 (StudentID, Course, CourseStatus) VALUES
(1, 'Math', 'Pass'),
(1, 'English', 'Fail'),
(1, 'Science', 'Pass'),
(2, 'Math', 'Fail'),
(2, 'English', 'Pass'),
(2, 'Science', 'Fail');