SQL 表值函数/标量函数

时间:2022-09-23 17:53:40

表值函数

定义表值函数

 --定义表值函数
CREATE FUNCTION GetStuScore(@Stu_ID INT )
RETURNS TABLE
AS RETURN
(SELECT
MAX('学生'+CONVERT(NCHAR(10),[Stu_ID])) AS 学生
,MAX(CASE WHEN Course='语文' THEN ISNULL(Score,0) ELSE 0 END) AS 语文成绩
,MAX(CASE WHEN Course='数学' THEN ISNULL(Score,0) ELSE 0 END) AS 数学成绩
,MAX(CASE WHEN Course='英语' THEN ISNULL(Score,0) ELSE 0 END) AS 英语成绩
,CONVERT(DECIMAL(4,1),ROUND(AVG(Score),1)) AS 平均成绩
FROM [EFDemo].[dbo].[Table_1]
GROUP BY Stu_ID HAVING Stu_ID=@Stu_ID)

使用表值函数

 --使用表值函数
SELECT * FROM GetStuScore(1)

SQL 表值函数/标量函数

标量函数

定义标量函数

 --定义标量函数
CREATE FUNCTION GetScore(@Stu_ID INT,@Course NVARCHAR(10))
RETURNS FLOAT
AS
BEGIN
DECLARE @Score FLOAT
SELECT @Score=Score FROM dbo.Table_1 WHERE Stu_ID=@Stu_ID AND Course=@Course
RETURN @Score
END

使用标量函数

--使用标量函数
SELECT GetScore(1,'语文')

SQL 表值函数/标量函数