sql >> データベース >  >> RDS >> Mysql

MySQLのsubstring_index関数に相当するSQLServer

    T-SQLとXQuery((root/row)[position() <= sql:variable("@count")]に基づいてこのソリューションを試してください ):

    T-SQLスカラー関数:

    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
    */
    

    または

    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
    
    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;
    

    出力:

    /*
    Value               Result
    ------------------- ---------------
    www.somewebsite.com www.somewebsite
    www.yahoo.com       www.yahoo
    www.outlook.com     www.outlook
    */
    


    1. ProxySQLとClusterControlを使用したMySQLとMariaDBのクエリキャッシュ

    2. SQL:すべての結合されたレコードが何らかの条件を満たすレコードを選択します

    3. HerokuとRails:PostgresでのGemロードエラー、ただしGEMFILEで指定

    4. PythonとMySQLデータベース:実用的な紹介