在Microsoft SQL Server 2008中,你可以實現把表格變數傳遞到存儲過程中,如果變數可以被聲明,那麼它就可以被傳遞。下麵我們來具體介紹如何把表格變數(包括內含的數據)傳遞到存儲過程和功能中去。 傳遞表值參數 用戶經常會碰到許多需要把數值容器而非單個數值放到存儲過程里的情況。對於大部 ...
在Microsoft SQL Server 2008中,你可以實現把表格變數傳遞到存儲過程中,如果變數可以被聲明,那麼它就可以被傳遞。下麵我們來具體介紹如何把表格變數(包括內含的數據)傳遞到存儲過程和功能中去。
傳遞表值參數 用戶經常會碰到許多需要把數值容器而非單個數值放到存儲過程里的情況。對於大部分的編程語言而言,把容器數據結構傳遞到常式里或傳遞出來是很常見而且很必要的功能。TSQL也不例外。SQL Server 2000通過OPENXML可以實現這個功能,用戶可以把數據存儲為VARCHAR數據類型然後進行傳遞。到了SQL Server 2005,隨著 XML數據類型以及XQuery的出現,這個功能變得容易一點。但用戶仍然需要對XML數據進行組建和粉碎才能夠使用它,因此這個功能使用起來並不簡單。SQL Server 2008則能夠把表值數據類型傳遞到存儲過程和功能中,從而大大地簡化了編程的工作,因為程式員無需再花心思去組建和解析XML數據了。該功能還可以讓客戶方開發員傳遞客戶方數據表格到資料庫中。
怎樣傳遞表格參數? 以銷售為例,首先建立一個 my SalesHistory表格,裡面包含了產品銷售的信息。寫以下腳本就可以在資料庫里創建你選擇的表格:
IF OBJECT_ID(‘SalesHistory‘)>0
DROP TABLE SalesHistory;
GO
CREATE TABLE [dbo].[SalesHistory] (
[SaleID] [int] IDENTITY(1,1) NOT NULL PRIMARY KEY,
[Product] [varchar](10) NULL,
[SaleDate] [datetime] NULL,
[SalePrice] [money] NULL )
GO
建立表值參數第一步是創建確切的表格類型,這一步非常重要,因為這樣你就可以在資料庫引擎里定義表格的結構,讓你可以在需要的時候在過程代碼里使用該表格。下麵的代碼創建 SalesHistoryTableType 表格類型定義:
CREATE TYPE SalesHistoryTableType AS TABLE (
[Product] [varchar](10) NULL,
[SaleDate] [datetime] NULL,
[SalePrice] [money] NULL )
GO
如果想要查看系統里其他類型的表格類型定義,你可以執行下麵這個查詢命令,查看系統目錄: SELECT * FROM sys.table_types我們需要定義用來處理表值參數的存儲過程。下麵這個程式能夠接受指定SalesHistoryTableType類型的表值參數,並載入到SalesHistory中,表值參數在Product列中的值為“BigScreen”:
CREATE PROCEDURE usp_InsertBigScreenProducts (
@TableVariable SalesHistoryTableType READONLY )
AS
BEGIN
INSERT INTO SalesHistory ( Product, SaleDate, SalePrice )
SELECT Product, SaleDate, SalePrice
FROM @TableVariable WHERE Product = ‘BigScreen‘
END
GO
傳遞的表格變數還可以用做任何其他表格的查詢數據。 傳遞表值參數功能的局限性 在傳遞表值變數到程式中時必須使用 READONLY從句。表格變數里的數據不能做修改——除了修改你可以把數據用於任何其他的操作。另外,你也不能把表格變數用做OUTPUT參數——只能用做input參數。 使用自己的新表格變數類型 首先,要聲明一個變數類型SalesHistoryTableType,不需要再一次定義表格結構,因為在創建這個表格類型的時候已經定義過了。 以下是代碼片段:
DECLARE @DataTable AS SalesHistoryTableType
--The following script adds 1,000 records into my @DataTable table variable:
DECLARE @i SMALLINT
SET @i = 1
WHILE (@i <=1000)
BEGIN
INSERT INTO @DataTable(Product,SaleDate,SalePrice)
VALUES('Computer',DATEADD(mm,@i,'3/11/1919'),DATEPART(ms,GETDATE()) + (@i + 57))
INSERT INTO @DataTable(Product, SaleDate, SalePrice)
VALUES('BigScreen', DATEADD(mm, @i, '3/11/1927'), DATEPART(ms, GETDATE()) + (@i + 13))
INSERT INTO @DataTable(Product, SaleDate, SalePrice)
VALUES('PoolTable', DATEADD(mm, @i, '3/11/1908'), DATEPART(ms, GETDATE()) + (@i + 29))
SET @i = @i + 1
END
只要把數據載入到表格變數里,就可以把結構傳遞到存儲過程中。 註意:當表格變數作為參數傳遞後,表格會在存儲在tempdb系統資料庫里,而不是傳遞整個數據集在記憶體里。因為這樣保證高效處理大批量數據。所有伺服器方的表格變數參數傳遞都是通過使用reference調用tempdb中的表格。 EXECUTE usp_InsertBigScreenProducts @TableVariable = @DataTable想要查詢程式是否和預想效果一樣,可以執行以下查詢來看記錄是否已經插入到 SalesHistory表格中: SELECT * FROM SalesHistory結論: 雖然SQL Server 2008資料庫的參數傳遞功能的使用還有一些局限性,比如不能修改參數中的數據和把變數用於output,但它已經很大程度的提高了程式性能,它可以減少server往返旅程數、利用表格限制並擴展編程在資料庫引擎中的功能。