SQL Server 2008:表值参数的创建和使用(3)_Mssql数据库教程

编辑Tag赚U币
教程Tag:暂无Tag,欢迎添加,赚取U币!

推荐:解析SQL Server数据应用在不同的数据库中
在软件开发的初始阶段,开发商们总是想把整个系统的最小的细节设计好了,然后再去单线程的编写代码。这样软件开发完成需要很长时间,但开发商们一直都在这么做。 所以开发者不得不去缩小他们

这个存储过程将表变量作为导入值接收,并且只插入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所有不匹配的行。

分享:快速清除SQLServer日志的两种方法
日志文件满而造成SQL数据库无法写入文件时,可用两种方法: 第一种方法:清空日志。 1、打开查询分析器,输入命令 DUMP TRANSACTION 数据库名 WITH NO_LOG 2、再打开企业管理器--右键你

来源:模板无忧//所属分类:Mssql数据库教程/更新时间:2008-08-22
相关Mssql数据库教程