Chinaunix首页 | 论坛 | 博客
  • 博客访问: 377171
  • 博文数量: 1051
  • 博客积分: 53280
  • 博客等级: 大将
  • 技术积分: 6670
  • 用 户 组: 普通用户
  • 注册时间: 2008-09-09 13:21
文章分类

全部博文(1051)

文章存档

2011年(1)

2008年(1050)

我的朋友

分类:

2008-09-09 16:32:27

    表值参数(Table-valued parameter)是SQL Server 2008的一个新特性,在以前的版本中,没有办法把表变量当作一个参数传递给过程。微软在SQL Server2008中引入了表值参数的特性,可以实现这项功能。

  表值参数有两大优点:一是它不需要为初始的数据加锁,二是它不会导致语句重新编译。

  表值参数的创建和使用包括以下步骤:

  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
  Create database TestDB
  go

    
    接下来我们使用以下的DDL SQL语句来创建一个名为TestLocationTable的表:

   

  USE [TestDB]
  GO
  IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[TestLocationTable]') AND type in (N'U'))
  DROP TABLE [dbo].[TestLocationTable]
  GO
  USE [TestDB]
  GO
  SET ANSI_NULLS ON
  GO
  SET QUOTED_IDENTIFIER ON
  GO
  SET ANSI_PADDING ON
  GO
  CREATE TABLE [dbo].[TestLocationTable](
  [Id] [int] NULL,
  [shortname] [char](3) NULL,
  [name] [varchar](100) NULL
  ) ON [PRIMARY]
  GO
  SET ANSI_PADDING OFF
  GO

[1]    

【责编:Zenghui】

--------------------next---------------------

阅读(122) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~