本文共 1121 字,大约阅读时间需要 3 分钟。
简介
T-SQL函数是一组或多组T-SQL语句组成的子程序,能够实现复杂操作或增加系统功能。SQL Server支持三种用户定义函数:
- 标量型函数(Scalar function):返回单个数据值。
- 内嵌表值型函数(Inline TABLE-valued function):以表形式返回结果。
- 多语句表值型函数(Multi-statement TABLE-valued function):结合标量型和内嵌表值型函数的一种形式。
创建函数
函数的创建遵循以下语法格式:
CREATE FUNCTION [当前用户].[函数名]([参数名1 [取值类型] [默认值], ...])RETURNS [返回类型][WITH 启用选项]AS BEGIN-- 函数体逻辑RETURN 返回值END
示例
-- 标量型函数示例
CREATE FUNCTION F_成绩分级 (@成绩 FLOAT)RETURNS CHAR(16)ASBEGINDECLARE @等级 CHAR(16)SELECT @等级 = CASEWHEN @成绩 IS NULL THEN '还没参加考试'WHEN @成绩 < 60 THEN '不及格'WHEN @成绩 BETWEEN '60' AND '70' THEN '及格'WHEN @成绩 BETWEEN '70' AND '80' THEN '中等'WHEN @成绩 BETWEEN '80' AND '90' THEN '良好'ELSE '优秀!'ENDRETURN (@等级)END
-- 内嵌表值型函数示例
CREATE FUNCTION F_学生信息 (@院系 CHAR(20))RETURNS TABLEASRETURN (SELECT 学号,姓名,性别,院系,专业,籍贯FROM 学生表WHERE 所在院系 = @院系)
调用函数
调用函数时,可通过以下方式实现:
函数名([参数名, ...])
删除函数
DROP FUNCTION 函数名
转载地址:http://uddiz.baihongyu.com/