热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

SQLServer2008:表值参数的创立和应用

表值参数(Table-valuedparameter)是SQLServer2008的一个新特征,在以前的版本中,没有措施把表变量当作一个参数传递给存储过程。微软在SQLServer2008中引进了表值参数的特征,可以实现这项
表值参数(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

然后,应用以下的DML SQL语句将数据添加到我们上面创立的表中:


  USE [TestDB]
  GO
  insert into TestLocationTable ( Id, shortname, Name) select 1, 'NA1', 'NewYork'
  insert into TestLocationTable ( Id, shortname, Name) select 2, 'NA2', 'NewYork'
  insert into TestLocationTable ( Id, shortname, Name) select 3, 'NA3', 'NewYork'
  insert into TestLocationTable ( Id, shortname, Name) select 4, 'EU1', 'London'
  insert into TestLocationTable ( Id, shortname, Name) select 5, 'EU2', 'London'
  insert into TestLocationTable ( Id, shortname, Name) select 6, 'AS1', 'Tokyo'
  insert into TestLocationTable ( Id, shortname, Name) select 7, 'AS2', 'HongKong'
  go

  下一步,我们要创立一个和TestLocationTable表具有类似表结构的表类型(TABLE TYPE),语句如下:


  USE [TestDB]
  GO
  IF EXISTS (SELECT * FROM sys.types st JOIN sys.schemas ss ON st.schema_id = ss.schema_id
  WHERE st.name = N'OfficeLocation_Tabetype' AND ss.name = N'dbo')
  DROP TYPE [dbo].[OfficeLocation_Tabetype]
  GO
  USE [TestDB]
  GO
  CREATE TYPE [dbo].[OfficeLocation_Tabetype] AS TABLE(
  [Id] [int] NULL,
  [shortname] [char](3) NULL,
  [name] [varchar](100) NULL
  )
  GO

  紧接着,我们要创立一个可以将表类型作为一个参数来接收的存储过程,应用的语句如下:


  USE [TestDB]
  GO
  IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[usp_InsertProdLocation]') AND type in (N'P', N'PC'))
  DROP PROCEDURE [dbo].[usp_selectProdLocation]
  GO
  CREATE PROCEDURE usp_InsertProdLocation
  @TVP OfficeLocation_Tabetype READONLY
  AS
  SET NOCOUNT ON
  INSERT INTO TestLocationTable Select ID, shortname, name from @TVP
  where convert(varchar(10),id) shortname name not in (select
  convert(varchar(10),id) shortname name from TestLocationTable)
  GO

这个存储过程将表变量作为导进值接收,并且只插进TestLocationTable中没有的数据。现在,我们可以尝试创立一个表变量,并履行上面创立的存储过程usp_InsertProdLocation,语句如下:


  use TestDB
  go
  DECLARE @TV AS [OfficeLocation_Tabetype]
  INSERT INTO @TV (Id, Shortname, Name) SELECT 12, 'ME1', 'Dubai'
  INSERT INTO @TV (Id, Shortname, Name) SELECT 13, 'ME2', 'Tehran'
  INSERT INTO @TV (Id, Shortname, Name) SELECT 17, 'EA1', 'Bombay'
  INSERT INTO @TV (Id, Shortname, Name) SELECT 18, 'EA2', 'Karachi'
  INSERT INTO @TV (Id, Shortname, Name) SELECT 3, 'NA3', 'NewYork'
  INSERT INTO @TV (Id, Shortname, Name) SELECT 4, 'EU1', 'London'
  exec usp_InsertProdLocation @TV
  go

  这时候,我们可以应用以下的TSQL语句从表TestLocationTable查询所有的数据:


  use TestDB
  go
  select * from TestLocationTable
  go

  查询成果如下所示:


  Id, shortname, name
  1, NA1, NewYork
  2, NA2, NewYork
  3, NA3, NewYork
  4, EU1, London
  5, EU2, London
  6, AS1, Tokyo
  7, AS2, HongKong
  12, ME1, Dubai
  13, ME2, Tehran
  17, EA1, Bombay
  18, EA2, Karachi
  (11 row(s) affected)

  从返回的成果,我们可以看到存储过程usp_InsertProdLocation 插进了表变量@TV中和表TestLocationTable所有不匹配的行。

推荐阅读
  • 本文深入探讨了SQL数据库中常见的面试问题,包括如何获取自增字段的当前值、防止SQL注入的方法、游标的作用与使用、索引的形式及其优缺点,以及事务和存储过程的概念。通过详细的解答和示例,帮助读者更好地理解和应对这些技术问题。 ... [详细]
  • 嵌入式开发环境搭建与文件传输指南
    本文详细介绍了如何为嵌入式应用开发搭建必要的软硬件环境,并提供了通过串口和网线两种方式将文件传输到开发板的具体步骤。适合Linux开发初学者参考。 ... [详细]
  • 本文详细介绍了在XAMPP环境中如何修改Apache和MySQL的默认端口号,并确保WordPress能够正常访问。同时,提供了针对Go语言社区和Golang开发者的相关建议。 ... [详细]
  • 本文探讨了如何通过预处理器开关选择不同的类实现,并解决在特定情况下遇到的链接器错误。 ... [详细]
  • 《蝴蝶之吻》:Bob Carlisle的深情献礼
    美国抒情乡村歌手Bob Carlisle在他女儿Brooke十六岁生日前夕,目睹她即将展翅高飞,心中感慨万千。他以这首《Butterfly Kisses》表达了对女儿无尽的父爱与美好回忆。 ... [详细]
  • 深入解析Serverless架构模式
    本文将详细介绍Serverless架构模式的核心概念、工作原理及其优势。通过对比传统架构,探讨Serverless如何简化应用开发与运维流程,并介绍当前主流的Serverless平台。 ... [详细]
  • 在 Android 开发中,通过 Intent 启动 Activity 或 Service 时,可以使用 putExtra 方法传递数据。接收方可以通过 getIntent().getExtras() 获取这些数据。本文将介绍如何使用 RoboGuice 框架简化这一过程,特别是 @InjectExtra 注解的使用。 ... [详细]
  • #print(34or4 ... [详细]
  • 本文将详细介绍多个流行的 Android 视频处理开源框架,包括 ijkplayer、FFmpeg、Vitamio、ExoPlayer 等。每个框架都有其独特的优势和应用场景,帮助开发者更高效地进行视频处理和播放。 ... [详细]
  • 本文探讨了为何相同的HTTP请求在两台不同操作系统(Windows与Ubuntu)的机器上会分别返回200 OK和429 Too Many Requests的状态码。我们将分析代码、环境差异及可能的影响因素。 ... [详细]
  • 本文将探讨2015年RCTF竞赛中的一道PWN题目——shaxian,重点分析其利用Fastbin和堆溢出的技巧。通过详细解析代码流程和漏洞利用过程,帮助读者理解此类题目的破解方法。 ... [详细]
  • 离线安装Grafana Cloudera Manager插件并监控CDH集群
    本文详细介绍如何离线安装Cloudera Manager (CM) 插件,并通过Grafana监控CDH集群的健康状况和资源使用情况。该插件利用CM提供的API接口进行数据获取和展示。 ... [详细]
  • CSS高级技巧:动态高亮当前页面导航
    本文介绍了如何使用CSS实现网站导航栏中当前页面的高亮显示,提升用户体验。通过为每个页面的body元素添加特定ID,并结合导航项的类名,可以轻松实现这一功能。 ... [详细]
  • 本文介绍下,在php编程中,用正则表达式判断某一字符串是否为域名的方法,有需要的朋友参考下吧。通常匹配域名的格式要求:1、域 ... [详细]
  • 探讨在PHP开发中,如何选择使用Cookie或数据库来优化网站性能,特别是在处理用户保存的搜索结果时。 ... [详细]
author-avatar
cui115588
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有