テーブル値関数: インライン vs. 複数ステートメント – パフォーマンス分析
インラインとマルチステートメントのテーブル値関数 (TVF) の選択は、クエリのパフォーマンスに大きな影響を与えます。 この比較では主な違いが強調され、最適な使用法に関するガイダンスが提供されます。
インライン テーブル値関数 (ITVF)
ITVF は、ビューと同様に、リアルタイムのテーブル構造と統計を活用し、多くの場合、優れた実行計画につながります。 以下に例を示します:
<code class="language-sql">CREATE FUNCTION MyNS.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</code>
複数ステートメントのテーブル値関数 (MSTVF)
MSTVF は事前定義されたテーブル構造を利用しており、リアルタイム統計にはアクセスできません。 それらの構造は次のように異なります:
<code class="language-sql">CREATE FUNCTION MyNS.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>
パフォーマンスに関する考慮事項
一般に、ITVF はリアルタイム統計を活用できるため、MSTVF よりも優れたパフォーマンスを発揮します。 ただし、ITVF 内で簡単に実装できない複雑な操作の場合は、MSTVF の方が効率的である可能性があります。
いつどの関数タイプを使用するか
次の場合に ITVF を選択します。
次の場合に MSTVF を選択します。
結論
ITVF と MSTVF の最適な選択は、特定のタスクに完全に依存します。 ただし、パフォーマンス上の利点とデータベース統計の有効活用のため、一般に ITVF が好まれます。
以上がインライン関数と複数ステートメントのテーブル値関数: どちらの方がパフォーマンスが優れていますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。