SQL2008表类型简介

 大家都知道在SQL2008中新增加了一种用户自定义类型--表类型,它的出现改变了之前函数、存储过程等在参数传递时无法直接对表变量进行传递的问题。

下面简单介绍下表类型的建立、使用。

1  表类型是一种用户自定义数据类型,创建、删除同其他数据类型。

创建:CREATE TYPE DistanceTable TABLE(Id bigint, LocationOne float, LocationTwo float, Distance float, DistrictBelonged varchar(200));--计算地区间距离

删除:DROP TYPE DistanceTable

2  使用已定义的表类型。

声明:DECLARE @Distance DistanceTable

赋值:INSERT INTO @Distance(Id, LocationOne, LocationTwo) VALUES(100, 55.3, 32.6)

         UPDATE @Distance SET Distance = ABS(LocationOne - LocationTwo)

3  在函数或存储过程中使用。

3.1 需要说明的是,作为参数表类型必须显式声明为只读变量,因此只能作为输入参数;

3.2 它和其他变量一样,与声明它的函数或存储过程是合成关系,也就是说它与该函数生命周期一致,函数调用结束,系统自动回收。

声明:DECLARE @Test DistanceTable

赋值:INSERT INTO @Test(Id, LocationOne, LocationTwo) VALUES(100, 55.3, 32.6)

函数:CREATE FUNCTION F_Deviation ( @Distance DistanceTable READONLY),

传参:select F_Deviation(@Test)--函数为标量函数

 

还可以用于一些复杂的函数或存储过程,它们之前需要用到多个临时表或表变量,现在直接使用表类型,可以少写许多表结构的代码,如:

之前:DECLARE @Table1(Id int, NumOfCourse int, NameOfCourse varchar(200));

         DECLARE @Table2(Id int, NumOfStudent int, NameOfStudent varchar(20));

现在:DECLARE @Table1 DistanceTable, @Table2 DistanceTable

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值