ホームページ  >  記事  >  データベース  >  SQL Server で MySQL の SUBSTRING_INDEX() 関数をレプリケートするにはどうすればよいですか?

SQL Server で MySQL の SUBSTRING_INDEX() 関数をレプリケートするにはどうすればよいですか?

Susan Sarandon
Susan Sarandonオリジナル
2024-11-16 01:36:02827ブラウズ

How to Replicate MySQL's SUBSTRING_INDEX() Function in SQL Server?

MySQL の SUBSTRING_INDEX() 関数と同等の SQL Server

MySQL SUBSTRING_INDEX() 関数は、数値に基づいて指定された文字列から部分文字列を抽出します。指定された区切り文字の出現回数。 SQL Server でこの機能を複製するには、いくつかのアプローチを使用できます。

1 つの方法では、T-SQL と 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

別のアプローチでは、インライン テーブルを利用します。 TSQL の -valued 関数:

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

これらのソリューションは両方とも、MySQL の効率的な代替手段を提供します。 SUBSTRING_INDEX() 関数。2 つのデータベース システム間でのクエリのシームレスな移植を可能にします。

以上がSQL Server で MySQL の SUBSTRING_INDEX() 関数をレプリケートするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。