SSMS
 sql >> Baza danych >  >> Database Tools >> SSMS

Dzielenie wartości oddzielonych przecinkami

Możesz utworzyć zdefiniowany przez użytkownika UDF, taki jak pokazany poniżej. Następnie po prostu przekaż listę oddzieloną przecinkami z innego zapytania, a zwróci ona tabelę z każdą wartością w osobnym wierszu.

CREATE FUNCTION [dbo].[fnSplitStringAsTable] 
(
    @inputString varchar(MAX),
    @delimiter char(1) = ','
)
RETURNS 
@Result TABLE 
(
    Value varchar(MAX)
)
AS
BEGIN
    DECLARE @chIndex int
    DECLARE @item varchar(100)

    -- While there are more delimiters...
    WHILE CHARINDEX(@delimiter, @inputString, 0) <> 0
        BEGIN
            -- Get the index of the first delimiter.
            SET @chIndex = CHARINDEX(@delimiter, @inputString, 0)

            -- Get all of the characters prior to the delimiter and insert the string into the table.
            SELECT @item = SUBSTRING(@inputString, 1, @chIndex - 1)

            IF LEN(@item) > 0
                BEGIN
                    INSERT INTO @Result(Value)
                    VALUES (@item)
                END

            -- Get the remainder of the string.
            SELECT @inputString = SUBSTRING(@inputString, @chIndex + 1, LEN(@inputString))
        END

    -- If there are still characters remaining in the string, insert them into the table.
    IF LEN(@inputString) > 0
        BEGIN
            INSERT INTO @Result(Value)
            VALUES (@inputString)
        END

    RETURN 
END


  1. DBeaver
  2.   
  3. phpMyAdmin
  4.   
  5. Navicat
  6.   
  7. SSMS
  8.   
  9. MySQL Workbench
  10.   
  11. SQLyog
  1. SQL LocalDB - Nie można usunąć bazy danych, gdy jej pliki są usuwane

  2. Widok schematu programu SQL Server Management Studio

  3. Nie można zalogować się do serwera w SQL Server 2008 R2 Management Studio

  4. ssms kopia bazy danych

  5. Jak wyświetlić wykonane zapytania w programie SQL Server Management Studio?