大家都知道在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