zoukankan      html  css  js  c++  java
  • 【原】[SQL function] SQL Server Split Function

    -- dbo.fnSplitToVarchar

    IF EXISTS    (SELECT * FROM INFORMATION_SCHEMA.ROUTINES WHERE ROUTINE_NAME = 'fnSplitToVarchar')
        
    BEGIN
            
    DROP FUNCTION fnSplitToVarchar
            
    IF NOT EXISTS    (SELECT * FROM INFORMATION_SCHEMA.ROUTINES WHERE ROUTINE_NAME = 'fnSplitToVarchar')
                
    PRINT 'DROP FUNCTION fnSplitToVarchar SUCCEEDED'
            
    ELSE
                
    PRINT 'DROP FUNCTION fnSplitToVarchar FAILED'
        
    END
    ELSE
        
    PRINT 'Attempting to CREATE FUNCTION dbo.fnSplitToVarchar'
    GO

    CREATE FUNCTION dbo.fnSplitToVarchar
    (
        
    @SourceSql varchar(8000),
        
    @StrSeprate varchar(10)
    )
        
    returns @temp table(splitValue varchar(500))

    AS
    BEGIN
        
    DECLARE @i int
        
    DECLARE @StrSeprateLength int
        
    SET @StrSeprateLength = LEN(@StrSeprate)
        
    SET @SourceSql    = RTRIM(LTRIM(@SourceSql))
        
    SET @i        = CHARINDEX(@StrSeprate@SourceSql)
        
    WHILE @i>=1
        
    BEGIN
            
    IF @i=1
                
    INSERT @temp VALUES('')
            
    ELSE
                
    INSERT @temp VALUES(LEFT(@SourceSql@i-1))
            
    SET @SourceSql    = SUBSTRING(@SourceSql@i+@StrSeprateLengthLEN(@SourceSql)-@i-@StrSeprateLength+1)
            
    SET @i        = CHARINDEX(@StrSeprate@SourceSql)
        
    END
        
    IF @SourceSql<>@StrSeprate
            
    INSERT @temp VALUES(@SourceSql)
        
    RETURN
    END

    GO

    IF EXISTS    (SELECT * FROM INFORMATION_SCHEMA.ROUTINES WHERE ROUTINE_NAME = 'fnSplitToVarchar')
        
    PRINT 'CREATE FUNCTION dbo.fnSplitToVarchar SUCCEEDED'
    ELSE
        
    PRINT 'CREATE FUNCTION dbo.fnSplitToVarchar FAILED'
    GO
  • 相关阅读:
    OpenGL模板 Mac Cmake OpenGL(Glut) Template
    CodeForces 277A Learning Languages (并检查集合)
    Linux netstat订购具体解释
    POJ 1936 All in All
    他的第一个NDK的Demo
    [ACM] POJ 2418 Hardwood Species (Trie树或map)
    Swift
    Swift
    Swift
    Swift
  • 原文地址:https://www.cnblogs.com/luckylei66/p/1425804.html
Copyright © 2011-2022 走看看