SQL Server 表值函數:內嵌函數與多語句函數的比較
SQL Server 的表值函數 (TVF) 允許從單一函數呼叫傳回多行資料。然而,TVF 主要分為兩種:多語句函數和內聯函數。
內聯表值函數 (ITVF)
ITVF 在函數定義中使用單一 SELECT 語句定義。它們的行為類似於視圖,繼承引用的列的資料類型、可空性和排序規則。
多語句表值函數 (MSTVF)
MSTVF 使用多個語句定義,通常會包含一個 INSERT 語句來填入表格變數。它們需要在函數定義中明確聲明列的資料類型和屬性。
效能差異
儘管語法不同,ITVF 和 MSTVF 的表現差異顯著。 ITVF 能夠充分利用 SQL Server 基於表格統計資料的查詢最佳化器,產生高效率的執行計劃。而 MSTVF 更像表變量,查詢優化器的最佳化效果較差,執行計劃效率相對較低。
適用場景
ITVF 和 MSTVF 的選擇取決於特定的應用場景。如果函數邏輯可以用簡單的 SELECT 語句表達,ITVF 通常更有效率,更值得推薦。當需要額外的處理或參數化時,MSTVF 更為適用。
範例
考慮以下範例:
<code class="language-sql">-- 内联表值函数 CREATE FUNCTION GetUnshippedOrders() RETURNS TABLE AS RETURN SELECT a.SaleId, a.CustomerID, b.Qty FROM Sales.Sales a INNER JOIN Sales.SaleDetail b ON a.SaleId = b.SaleId INNER JOIN Production.Product c ON b.ProductID = c.ProductID WHERE a.ShipDate IS NULL GO -- 多语句表值函数 CREATE FUNCTION GetLastShipped(@CustomerID INT) RETURNS @CustomerOrder TABLE (SaleOrderID INT NOT NULL, CustomerID INT NOT NULL, OrderDate DATETIME NOT NULL, OrderQty INT NOT NULL) AS BEGIN DECLARE @MaxDate DATETIME SELECT @MaxDate = MAX(OrderDate) FROM Sales.SalesOrderHeader WHERE CustomerID = @CustomerID INSERT @CustomerOrder SELECT a.SalesOrderID, a.CustomerID, a.OrderDate, b.OrderQty FROM Sales.SalesOrderHeader a INNER JOIN Sales.SalesOrderHeader b ON a.SalesOrderID = b.SalesOrderID INNER JOIN Production.Product c ON b.ProductID = c.ProductID WHERE a.OrderDate = @MaxDate AND a.CustomerID = @CustomerID RETURN END GO</code>
在這個例子中,MSTVF 用於計算特定客戶的最後一次發貨訂單,這需要額外的處理。而 ITVF 只需檢索所有未發貨訂單的列表,更適合簡單的過濾操作。
以上是SQL Server 中的內嵌函數與多語句表值函數:您應該選擇哪一個?的詳細內容。更多資訊請關注PHP中文網其他相關文章!