Tabellenwertfunktionen von SQL Server: Vergleich von Inline-Funktionen und Funktionen mit mehreren Anweisungen
Die Tabellenwertfunktionen (TVFs) von SQL Server ermöglichen die Rückgabe mehrerer Datenzeilen aus einem einzigen Funktionsaufruf. TVFs werden jedoch hauptsächlich in zwei Typen unterteilt: Funktionen mit mehreren Anweisungen und Inline-Funktionen.
Inline-Tabellenwertfunktion (ITVF)
ITVF wird mithilfe einer einzelnen SELECT-Anweisung innerhalb der Funktionsdefinition definiert. Sie verhalten sich wie Ansichten und erben den Datentyp, die NULL-Zulässigkeit und die Sortierung der referenzierten Spalten.
Multiple Statement Table Value Function (MSTVF)
MSTVF wird mithilfe mehrerer Anweisungen definiert, normalerweise einschließlich einer INSERT-Anweisung zum Füllen von Tabellenvariablen. Sie erfordern eine explizite Deklaration des Datentyps und der Eigenschaften der Spalte in der Funktionsdefinition.
Leistungsunterschied
Trotz der unterschiedlichen Syntax ist der Leistungsunterschied zwischen ITVF und MSTVF erheblich. ITVF nutzt den auf Tabellenstatistiken basierenden Abfrageoptimierer von SQL Server voll aus, um effiziente Ausführungspläne zu generieren. MSTVF ähnelt eher einer Tabellenvariablen, der Abfrageoptimierer hat einen schlechten Optimierungseffekt und die Effizienz des Ausführungsplans ist relativ gering.
Anwendbare Szenarien
Die Wahl von ITVF und MSTVF hängt vom jeweiligen Anwendungsszenario ab. Wenn die Funktionslogik in einer einfachen SELECT-Anweisung ausgedrückt werden kann, ist ITVF normalerweise effizienter und wird empfohlen. MSTVF eignet sich besser, wenn zusätzliche Verarbeitung oder Parametrisierung erforderlich ist.
Beispiel
Betrachten Sie das folgende Beispiel:
<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>
In diesem Beispiel wird MSTVF verwendet, um die letzte versendete Bestellung für einen bestimmten Kunden zu berechnen, was eine zusätzliche Verarbeitung erfordert. ITVF muss lediglich die Liste aller nicht versendeten Bestellungen abrufen, was für einfache Filtervorgänge besser geeignet ist.
Das obige ist der detaillierte Inhalt vonInline- oder Multi-Statement-Tabellenwertfunktionen in SQL Server: Welche sollten Sie wählen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!