您的位置:首页 > 数据库

SQL2008表类型简介

2009-03-31 15:20 204 查看
 大家都知道在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

 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息