SQL Server-Äquivalent der Funktion substring_index in MySQL
Die Funktion substring_index in MySQL wird verwendet, um eine Teilzeichenfolge aus einer angegebenen Zeichenfolge vor einer bestimmten zu extrahieren Anzahl der Vorkommen eines Trennzeichens. Um eine ähnliche Funktionalität in SQL Server 2012 zu erreichen, können Sie einen der folgenden Ansätze verwenden:
T-SQL-Skalarfunktion:
CREATE FUNCTION dbo.SUBSTRING_INDEX ( @str NVARCHAR(4000), @delim NVARCHAR(1), @count INT ) RETURNS NVARCHAR(4000) WITH SCHEMABINDING BEGIN -- Convert the string to an XML document for processing DECLARE @XmlSourceString XML; SET @XmlSourceString = (SELECT N'<root><row>' REPLACE( (SELECT @str AS '*' FOR XML PATH('')) , @delim, N'</row><row>' ) N'</row></root>'); -- Extract the desired substring using XQuery RETURN STUFF ( (( SELECT @delim x.XmlCol.value(N'(text())[1]', N'NVARCHAR(4000)') AS '*' FROM @XmlSourceString.nodes(N'(root/row)[position() <= sql:variable("@count")]') x(XmlCol) FOR XML PATH(N''), TYPE ).value(N'.', N'NVARCHAR(4000)')), 1, 1, N'' ); END GO -- Example usage SELECT dbo.SUBSTRING_INDEX(N'www.somewebsite.com', N'.', 2) AS Result;
T-SQL Inline Table-Valued Function:
CREATE FUNCTION dbo.SUBSTRING_INDEX ( @str NVARCHAR(4000), @delim NVARCHAR(1), @count INT ) RETURNS TABLE AS RETURN WITH Base AS ( SELECT XmlSourceString = CONVERT(XML, (SELECT N'<root><row>' REPLACE( (SELECT @str AS '*' FOR XML PATH('')) , @delim, N'</row><row>' ) N'</row></root>')) ) SELECT STUFF ( (( SELECT @delim x.XmlCol.value(N'(text())[1]', N'NVARCHAR(4000)') AS '*' FROM Base b CROSS APPLY b.XmlSourceString.nodes(N'(root/row)[position() <= sql:variable("@count")]') x(XmlCol) FOR XML PATH(N''), TYPE ).value(N'.', N'NVARCHAR(4000)')), 1, 1, N'' ) AS Result; GO -- Example usage SELECT * FROM ( SELECT N'www.somewebsite.com' UNION ALL SELECT N'www.yahoo.com' UNION ALL SELECT N'www.outlook.com' ) a(Value) CROSS APPLY dbo.SUBSTRING_INDEX(a.Value, N'.', 2) b;
Mit diesen Funktionen können Sie das Verhalten der MySQL-Funktion substring_index in SQL Server replizieren und so Teilzeichenfolgen-Extraktionsaufgaben portabel durchführen .
Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.
Copyright© 2022 湘ICP备2022001581号-3