表值参数(Table-valued parameter)是SQL Server数据库2008的新特性之一,在以往的版本中,我们没有办法把表变量当作一个参数传递给存储过程。但在微软的SQL Server 2008中引入了表值参数这个特性,它可以实现此类功能。
表值参数有两个明显的优点:
1:不需要为初始的数据加锁。
2:它不会导致语句重新编译。
表值参数的创建和使用包括以下步骤:
(1) 创建表类型
(2) 创建一个可将表类型作为参数来接受的存储过程或函数
(3) 创建表变量并插入数据
(4) 调用该存储过程和函数,并将表变量作为参数传递。
下面,我们来一步步分解这个创建和使用的过程。首先,我们用以下的DDL SQL语句来创建一个名为“TestDB”的测试数据库:
USE [master]
GO
IF EXISTS (SELECT name FROM sys.databases WHERE name = N'TestDB')
DROP DATABASE TestDB
GO
Creat...[ 查看全文 ]