SQL Server Setara dengan Fungsi SUBSTRING_INDEX() MySQL
Fungsi MySQL SUBSTRING_INDEX() mengekstrak subrentetan daripada rentetan yang diberikan berdasarkan nombor kejadian pembatas tertentu. Untuk meniru fungsi ini dalam SQL Server, beberapa pendekatan boleh digunakan.
Satu kaedah melibatkan memanfaatkan T-SQL dan XQuery untuk mencipta fungsi skalar:
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
Pendekatan lain menggunakan jadual sebaris -fungsi bernilai dalam TSQL:
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
Kedua-dua penyelesaian ini menyediakan alternatif yang cekap kepada Fungsi SUBSTRING_INDEX() MySQL, membolehkan pemindahan pertanyaan yang lancar antara kedua-dua sistem pangkalan data.
Atas ialah kandungan terperinci Bagaimana untuk Meniru Fungsi SUBSTRING_INDEX() MySQL dalam Pelayan SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!