DataBase/SQL Server

SP 에서 특정문자열을 기준으로 데이타를 테이블로 반환한다.

탑~! 2010. 12. 2. 17:58

CREATE FUNCTION [dbo].[F_SB_Split]
(
    @StrValue VARCHAR(1000), -- 대상 문자열
    @SplitChar CHAR(1)   -- 구분자
)
RETURNS @SPLIT_TEMP TABLE  ( RtnValue VARCHAR(50) )
AS
BEGIN  
    DECLARE @sPos INT, @nPos INT
    DECLARE @TmpVar VARCHAR(1000) -- 분리된 문자열 임시 저장변수
 
    SET @sPos = 1 -- 구분문자 검색을 시작할 위치
    SET @nPos = 1 -- 구분문자 위치

    WHILE (@nPos > 0)
    BEGIN
        SET @nPos = CHARINDEX(@SplitChar, @StrValue, @sPos )

        IF @nPos = 0
            SET @TmpVar = RIGHT(@StrValue, LEN(@StrValue)-@sPos+1 )
        ELSE
            SET @TmpVar = SUBSTRING(@StrValue, @sPos, @nPos-@sPos)

        IF LEN(@TmpVar)>0
            INSERT INTO @SPLIT_TEMP VALUES( @TmpVar )

        SET @sPos = @nPos + 1
    END
 
 RETURN
END

728x90
반응형