SQL语句--简单的函数书写举例(4)

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 

上一篇:简单的表值函数举例

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值