SQL Server 2008数据库中使用表值参数

SQL Server 2008数据库中使用表值参数,第1张

概述摘要:在SQL Server 2005或更早的版本中的数据库中,表变量是不能作为存储过程的参数的。SQL Server 2008中的T-SQL功能新增了表值参数。利用这个新增特性,我们可以很方便的将一个表作为参数传给存储过程,减少了应用程序与SQL Server数据库服务器之间的交互,提升了程序性能。 在SQL Server 2005或…

摘要:在sql Server 2005或更早的版本中的数据库中,表变量是不能作为存储过程的参数的。sql Server 2008中的T-sql功能新增了表值参数。利用这个新增特性,我们可以很方便的将一个表作为参数传给存储过程,减少了应用程序与sql Server数据库服务器之间的交互,提升了程序性能。

在sql Server 2005或更早的版本中的数据库中,表变量是不能作为存储过程的参数的。当多行数据到sql Server需要发送多行数据到sql Server ,开发者要么每次发送一列记录,或想出其他的变通方法,以满足需求。虽然在.net 2.0中提供了个sqlBulkcopy对象能够将多个数据行一次性传送给sql Server,但是多行数据仍然无法一次性传给存储过程。

sql Server 2008中的T-sql功能新增了表值参数。利用这个新增特性,我们可以很方便地通过T-SQL语句,或者通过一个应用程序,将一个表作为参数传给存储过程。

1、用户自定义表类型

当第一次看看新的表值参数,我认为使用此功能有点复杂。有几个步骤。要做的第一件事是定义表型。在Management Studio 2008中的“Programmability”“Type”节点,您可以看到“user-defined table Types(用户自定义表类型)”,如图1所示 。

 

 

图 1:用户自定义表类型

点击右键,在d出菜单中选择“新用户定义的表型... ” ,会新建一个模板中的查询窗口,如图2所示 。

 

 

图2:用户自定义表类型创建语句

点击“Specify Values for Template Parameters(指定值为模板参数)”按钮,将探出一个对话框,如图3所示。

 

 

图 3:指定模板参数列的数值

在填写在适当的数值之后,点击确定按钮,一个“CREATE TYPE”的声明取代了范本。这时,你也可以手动增加一些列,或者增加一些限制条件,最后点击确定按钮。

以下是最终的代码:

 

-- ================================-- Create user-defined table Type-- ================================USE TestGO-- Create the data typeCREATE TYPE dbo.MyType AS table (	col1 int NOT NulL,col2 varchar(20) NulL,col3 datetime NulL,PRIMARY KEY (col1))GO


 

在运行代码之后,对象的定义就建立好了,你可以在“user-defined table Type(用户自定义表类型”中查看属性,如图4所示,但没法修改它们。如果要修改的类型,你只能将其删除,然后按照修改后的属性再次创建它。

 

 

图4:查看用户自定义表类型的属性

2、使用用户自定义的表类型

如果打算在T-sql代码中使用,您还必须创建一个新类型的变量,然后将具体的表的名称赋值给该变量。一旦赋值后,您可以在其他的T-SQL语句中使用它。因为它是一个变量,在批处理完成后,它也自动失效,结束生命周期。

请注意下面的代码,MyType是我们之前刚刚创建的数据类型。

 

DECLARE @Mytable MyTypeINSERT INTO @Mytable(col1,col2,col3)VALUES (1,'abc','1/1/2000'),(2,'def','1/1/2001'),(3,'ghi','1/1/2002'),(4,'jkl','1/1/2003'),(5,'mno','1/1/2004')	SELECT * FROM @Mytable


 

在变量的有效范围内,你可以象 *** 作正常的表一样来 *** 作这个变量,如与另一个表象关联或者将变量中的记录填充到另一个表。对于表变量来说,你无法修改表定义。

正如前面提到的,变量不能超出它的有效的范围。如果T-sql脚本由多个批处理组成,变量只有在批处理内才能创建并有效使用。 总结

以上是内存溢出为你收集整理的SQL Server 2008数据库中使用表值参数全部内容,希望文章能够帮你解决SQL Server 2008数据库中使用表值参数所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1151432.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存