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
下面简单介绍下表类型的建立、使用。
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
相关文章推荐
- 02. redis 数据类型简介
- SQL2008入门教程-数据类型
- 运算符与类型转换 mogondb简介
- C语言基本数据类型简介
- SQL Server数据类型简介
- js简介及js基本数据类型
- SQL Server数据类型简介
- XML简介之Schema之 XSD 仅含文本复合元素 VS XSD 带有混合内容的复合类型
- XML简介Schema之XSD 杂项数据类型 VS XML总结
- Java基础之八大基本类型简介
- JavaScript中的Date类型详解与moment简介
- Redis数据类型简介
- 存储类型简介
- 移动端开发类型简介及Ionic开发环境配置
- Delphi中的各种方法类型简介
- DB2时间日期类型简介
- 数据库操作语句类型(DQL、DML、DDL、DCL)简介
- MIME类型简介
- Android 绑定类型服务---简介
- [Objective-C]简介、数据类型、NSLog、运算符