SQL Server 2008:传递表值参数
2007-12-04 09:50:36 来源:WEB开发网 CREATETYPESalesHistoryTableTypeASTABLE
(
[Product][varchar](10)NULL,
[SaleDate][datetime]NULL,
[SalePrice][money]NULL
)
GO
如果想要查看系统里其他类型的表格类型定义,你可以执行下面这个查询命令,查看系统目录:
SELECT * FROM sys.table_types
我们需要定义用来处理表值参数的存储过程。下面这个程序能够接受指定SalesHistoryTableType类型的表值参数,并加载到SalesHistory中,表值参数在Product列中的值为“BigScreen”:
CREATEPROCEDUREusp_InsertBigScreenProducts
(
@TableVariableSalesHistoryTableTypeREADONLY
)
AS
BEGIN
INSERTINTOSalesHistory
(
Product,SaleDate,SalePrice
)
SELECT
Product,SaleDate,SalePrice
FROM
@TableVariable
WHERE
Product='BigScreen'
END
GO
传递的表格变量还可以用做任何其他表格的查询数据。
传递表值参数功能的局限性
在传递表值变量到程序中时必须使用 READONLY从句。表格变量里的数据不能做修改——除了修改你可以把数据用于任何其他的操作。另外,你也不能把表格变量用做OUTPUT参数——只能用做input参数。
使用自己的新表格变量类型
首先,要声明一个变量类型SalesHistoryTableType,不需要再一次定义表格结构,因为在创建这个表格类型的时候已经定义过了。
DECLARE@DataTableASSalesHistoryTableType
Thefollowingscriptadds1,000recordsintomy@DataTabletablevariable:
DECLARE@iSMALLINT
SET@i=1
WHILE(@i<=1000)
BEGIN
INSERTINTO@DataTable(Product,SaleDate,SalePrice)
VALUES('Computer',DATEADD(mm,@i,'3/11/1919'),DATEPART(ms,GETDATE())+(@i+57))
INSERTINTO@DataTable(Product,SaleDate,SalePrice)
VALUES('BigScreen',DATEADD(mm,@i,'3/11/1927'),DATEPART(ms,GETDATE())+(@i+13))
INSERTINTO@DataTable(Product,SaleDate,SalePrice)
VALUES('PoolTable',DATEADD(mm,@i,'3/11/1908'),DATEPART(ms,GETDATE())+(@i+29))
SET@i=@i+1
END
只要把数据加载到表格变量里,就可以把结构传递到存储过程中。
注意:当表格变量作为参数传递后,表格会在存储在tempdb系统数据库里,而不是传递整个数据集在内存里。因为这样保证高效处理大批量数据。所有服务器方的表格变量参数传递都是通过使用reference调用tempdb中的表格。
EXECUTEusp_InsertBigScreenProducts
@TableVariable=@DataTable
想要查询程序是否和预想效果一样,可以执行以下查询来看记录是否已经插入到 SalesHistory表格中:
SELECT * FROM SalesHistory
总结:
虽然SQL Server 2008的参数传递功能的使用还有一些小小的局限性,比如不能修改参数中的数据和把变量用于output,但是它大大提高了程序性能,它可以减少server往返旅程数、利用表格限制并扩展编程在数据库引擎中的功能。
- ››sql server自动生成批量执行SQL脚本的批处理
- ››sql server 2008亿万数据性能优化
- ››SQL Server 2008清空数据库日志方法
- ››sqlserver安装和简单的使用
- ››SQL Sever 2008 R2 数据库管理
- ››SQL SERVER无法安装成功,sqlstp.log文件提示[未发...
- ››Sql Server中通过父记录查找出所有关联的子记录
- ››SqlServer触发器、存储过程和函数
- ››SQL Server 中的事务(含义,属性,管理)
- ››Sqlite数据库插入和读取图片数据
- ››Sql server 2005拒绝了对对象 'xx表' (数...
- ››Sql server 2005拒绝了对对象 'xx表' (数...
更多精彩
赞助商链接