將查詢從 MySQL 移轉到 SQL Server 時,通常需要尋找常用 MySQL 函數的 SQL Server 等效項。
MySQL 的 SUBSTRING_INDEX() 函數根據指定分隔符號的出現從給定字串中檢索子字串。其語法為:
SUBSTRING_INDEX(str, delim, count)
例如:
SELECT SUBSTRING_INDEX('www.somewebsite.com','.',2);
這將傳回 'www.somewebsite'。
T-SQL 中用於複製 SUBSTRING_INDEX() 功能的可行選項是 XQuery與標量函數的組合:
CREATE FUNCTION dbo.SUBSTRING_INDEX ( @str NVARCHAR(4000), @delim NVARCHAR(1), @count INT ) RETURNS NVARCHAR(4000) WITH SCHEMABINDING BEGIN DECLARE @XmlSourceString XML; SET @XmlSourceString = (SELECT N'<root><row>' + REPLACE( (SELECT @str AS '*' FOR XML PATH('')) , @delim, N'</row><row>' ) + N'</row></root>'); 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
範例用法:
SELECT dbo.SUBSTRING_INDEX(N'www.somewebsite.com', N'.', 2) AS Result;
輸出:
Result --------------- www.somewebsite
以上是如何在 SQL Server 中複製 MySQL 的 SUBSTRING_INDEX 函數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!