SQL语句–简单的函数书写举例(4)
本篇- - -稍稍复杂的【表值函数】案例
时刻记着,表值函数返回的结果是一个表
我想达到的目的是: 输入“1个员工的ID”,能返回(输出)“该员工的Name”、“该员工的DepartmentName”和“收入支出income/outcome”
【1.创建函数】
eg:
------------------------------------创建函数 Employee_INFO-----------------------------
CREATE FUNCTION Employee_INFO(@EmployeeID int)
--CREATE FUNCTION 函数名(@参数 数据类型)
RETURNS @Einfo TABLE
(
EName CHAR(20),
DName CHAR(20),
INcome CHAR(20),
OUTcome CHAR(20))
--返回一个表 @Einfo,这个表有4列:EName、DName、INcome、OUTcome
AS
BEGIN
INSERT INTO @Einfo
SELECT
t1.Name,
t2.DepartmentName,
t3.INcome,
t3.OUTcome
FROM dbo.Employee t1
INNER JOIN dbo.Department t2 ON t1.DepartmentID=t2.DepartmentID
INNER JOIN dbo.Salary t3 ON t1.EmployeeID=t3.EmployeeID
WHERE t1.EmployeeID=@EmployeeID ---特别注意下
RETURN
END
GO
--这里引申1个复制表的语法 INSERT INTO SELECT
--将 select出的结果集 复制到 INSERT INTO 后的 @Einfo 表中
【2.查询函数】
eg:
------------------------------------查询函数 Employee_INFO----------------------------
SELECT * FROM Employee_INFO(3002)
---查询员工编号为“3002”的 姓名,系别,收入支出情况
返回结果:
验证结果准确性:
由下图可见,编号【3002】的员工叫【赵军】
由下图可见,编号【3002】的员工收入支出分别为【4100】、【1800】
结果正确
【3.修改函数】
------------------------------------修改函数 dbo.Employee_INFO-------------------------
ALTER FUNCTION Employee_INFO(@EmployeeID CHAR(20))
---将参数的数据类型改为了char
RETURNS @Einfo TABLE
(
EName CHAR(20),
DName CHAR(20),
INcome CHAR(20),
OUTcome CHAR(20))
AS
BEGIN
INSERT INTO @Einfo
SELECT
t1.Name,
t2.DepartmentName,
t3.INcome,
t3.OUTcome
FROM dbo.Employee t1
INNER JOIN dbo.Department t2 ON t1.DepartmentID=t2.DepartmentID
INNER JOIN dbo.Salary t3 ON t1.EmployeeID=t3.EmployeeID
WHERE t1.EmployeeID=@EmployeeID
RETURN
END
GO
【4.删除函数】
当我们想删除该函数时,执行下面的语句即可:
------------------------------------删除函数 dbo.Employee_INFO-------------------
DROP FUNCTION dbo.Employee_INFO