SQL Server 2008:传递表值参数 (2)

本文介绍如何在SQL Server 2008中使用表值参数,并讨论了其局限性,如不能修改参数中的数据及作为输出参数等。通过实例展示了如何声明表值变量并将其作为输入参数传递给存储过程。



传递表值参数功能的局限性

 

  在传递表值变量到程序中时必须使用 READONLY从句。表格变量里的数据不能做修改——除了修改你可以把数据用于任何其他的操作。另外,你也不能把表格变量用做OUTPUT参数——只能用做input参数。

  使用自己的新表格变量类型

  首先,要声明一个变量类型SalesHistoryTableType,不需要再一次定义表格结构,因为在创建这个表格类型的时候已经定义过了。

  DECLARE @DataTable AS SalesHistoryTableType
  The following script adds 1,000 records into my @DataTable table variable:
  DECLARE @i SMALLINT
  SET @i = 1
  WHILE (@i <=1000)
  BEGIN
  INSERT INTO @DataTable(Product, SaleDate, SalePrice)
  VALUES ('Computer', DATEADD(mm, @i, '3/11/1919'), DATEPART(ms, GETDATE()) + (@i + 57))
  INSERT INTO @DataTable(Product, SaleDate, SalePrice)
  VALUES('BigScreen', DATEADD(mm, @i, '3/11/1927'), DATEPART(ms, GETDATE()) + (@i + 13))
  INSERT INTO @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中的表格。

  EXECUTE usp_InsertBigScreenProducts
  @TableVariable = @DataTable

  想要查询程序是否和预想效果一样,可以执行以下查询来看记录是否已经插入到 SalesHistory表格中:

  SELECT * FROM SalesHistory

  总结:

  虽然SQL Server 2008的参数传递功能的使用还有一些小小的局限性,比如不能修改参数中的数据和把变量用于output,但是它大大提高了程序性能,它可以减少server往返旅程数、利用表格限制并扩展编程在数据库引擎中的功能。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值