久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

拆分字符串放入數組

Split string put into an array(拆分字符串放入數組)
本文介紹了拆分字符串放入數組的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

我正在處理拆分字符串的 SQL Server 面部問題.我想實現一個將字符串拆分為數組的函數:

I am working on a SQL Server face problem which is splitting a string. I want to implement a function to split a string into an array:

Declare @SQL as varchar(4000)
Set @SQL='3454545,222,555'
Print @SQL

...我必須做的,所以我有一個數組:

total splitCounter=3
Arr(0)='3454545'
Arr(1)='222'
Arr(2)='555'

下面的split函數不能滿足我上面的需要,把一個字符串拆分成一個數組.

Below split function doesn't satisfy my need above, splitting a string into an array.

CREATE FUNCTION [dbo].[SplitString]
(
    @String     varchar(max)
,   @Separator  varchar(10)
)
RETURNS TABLE
AS RETURN
(
    WITH
    Split AS (
        SELECT
            LEFT(@String, CHARINDEX(@Separator, @String, 0) - 1) AS StringPart
        ,   RIGHT(@String, LEN(@String) - CHARINDEX(@Separator, @String, 0)) AS RemainingString

        UNION ALL

        SELECT
            CASE
                WHEN CHARINDEX(@Separator, Split.RemainingString, 0) = 0 THEN Split.RemainingString
                ELSE LEFT(Split.RemainingString, CHARINDEX(@Separator, Split.RemainingString, 0) - 1)
            END AS StringPart
        ,   CASE
                WHEN CHARINDEX(@Separator, Split.RemainingString, 0) = 0 THEN ''
                ELSE RIGHT(Split.RemainingString, LEN(Split.RemainingString) - CHARINDEX(@Separator, Split.RemainingString, 0))
            END AS RemainingString
        FROM
            Split
        WHERE
            Split.RemainingString <> ''
    )

    SELECT
        StringPart
    FROM
        Split
)

如果您有任何疑問,請提前提問,謝謝.任何類型的建議都將被接受.

If you have any query please ask, thanks in advance. Any type of suggestion will be accepted.

推薦答案

Split function from 這里

Split function from Here

CREATE FUNCTION [dbo].[fnSplitString] 
( 
    @string NVARCHAR(MAX), 
    @delimiter CHAR(1) 
) 
RETURNS @output TABLE(splitdata NVARCHAR(MAX) 
) 
BEGIN 
    DECLARE @start INT, @end INT 
    SELECT @start = 1, @end = CHARINDEX(@delimiter, @string) 
    WHILE @start < LEN(@string) + 1 BEGIN 
        IF @end = 0  
            SET @end = LEN(@string) + 1

        INSERT INTO @output (splitdata)  
        VALUES(SUBSTRING(@string, @start, @end - @start)) 
        SET @start = @end + 1 
        SET @end = CHARINDEX(@delimiter, @string, @start)

    END 
    RETURN 
END

從函數中選擇:

select *  FROM dbo.fnSplitString('3454545,222,555', ',')

退貨

splitdata 
--------
3454545 
222
555

然后,如果您愿意,可以使用游標或 while 循環將每個人分配給一個變量.一個表本質上是一個數組.

Then using a cursor or a while loop assign each individual to a variable if you wish. A table is in-essence an array already.

這篇關于拆分字符串放入數組的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

Modify Existing decimal places info(修改現有小數位信息)
The correlation name #39;CONVERT#39; is specified multiple times(多次指定相關名稱“CONVERT)
T-SQL left join not returning null columns(T-SQL 左連接不返回空列)
remove duplicates from comma or pipeline operator string(從逗號或管道運算符字符串中刪除重復項)
Change an iterative query to a relational set-based query(將迭代查詢更改為基于關系集的查詢)
concatenate a zero onto sql server select value shows 4 digits still and not 5(將零連接到 sql server 選擇值仍然顯示 4 位而不是 5)
主站蜘蛛池模板: 国产一区二 | 一区二区电影网 | 国产一区二区自拍 | 日本不卡视频在线播放 | 99久久亚洲 | 九色网址 | 婷婷综合色 | 国产成人精品在线播放 | 国产高清一区二区三区 | 久久久蜜桃| 在线视频 亚洲 | 久久精品久久久 | av黄色在线 | 四虎精品在线 | 日本一区二区高清视频 | 婷婷二区 | 91精品国产91久久久久久三级 | 成人av一区 | 国产一区二区三区四区五区加勒比 | 天天综合久久 | 欧美亚洲视频在线观看 | 亚洲福利一区二区 | 日韩精品一区二区三区在线播放 | 国产美女在线观看 | av网站在线免费观看 | 九九热这里 | 一区二区国产在线 | 日韩欧美在线不卡 | 亚洲视频www | 久久精品日 | 中文字幕 国产 | 日韩在线成人 | 视频一区在线观看 | 久久久久黄色 | 伊人春色在线 | 久久极品 | 91精品久久久久久久久中文字幕 | 91亚洲国产 | 毛片99| 欧美精品一区在线 | www国产精品|