Sqlserver
 sql >> Baza danych >  >> RDS >> Sqlserver

Jak odwrócić słowa w kolumnie

Do wykonania tego zadania potrzebna jest funkcja t-sql i kursor. fn_SplitList umożliwia dzielenie na podstawie ogranicznika. Gdy już masz tę funkcję, możesz utworzyć kursor, który będzie poruszał się po danych, aktualizując każdy rekord. Stworzyłem przykład używając @table1.

Funkcja

CREATE FUNCTION [dbo].[fn_SplitList]
(
    @RowData varchar(8000),
    @SplitOn varchar(5)
)  
RETURNS @RtnValue table 
(
    Id int identity(1,1),
    Data varchar(100)
) 
AS  
BEGIN 
    Declare @Cnt int
    Set @Cnt = 1

    While (Charindex(@SplitOn,@RowData)>0)
    Begin
        Insert Into @RtnValue (data)
        Select 
            Data = ltrim(rtrim(Substring(@RowData,1,Charindex(@SplitOn,@RowData)-1)))

        Set @RowData = Substring(@RowData,Charindex(@SplitOn,@RowData)+1,len(@RowData))
        Set @Cnt = @Cnt + 1
    End

    Insert Into @RtnValue (data)
    Select Data = ltrim(rtrim(@RowData))

    Return
END

Kod do wykonania aktualizacji

declare @table1 table(id int primary key
                     ,words varchar(max))
declare @id int
declare @words varchar(max)

insert into @table1 values(0, 'word1, word2, , word3, word4')
insert into @table1 values(1, 'word1, word2, word3, ,')
insert into @table1 values(2, 'word1,,,, ; word2')
insert into @table1 values(3, ';word1 word2, word3')

declare updateCursor cursor for
select id
      ,words
  from @table1

open updateCursor   
fetch next from updateCursor into @id, @words
while @@fetch_status = 0
begin
  declare @row varchar(255)

  select @row = coalesce(@row+', ', '') + data
    from dbo.fn_SplitList(@words, ',')
  order by id desc

  update @table1
     set words = @row
   where id = @id

  fetch next from updateCursor into @id, @words
end
close updateCursor   
deallocate updateCursor

select *
  from @table1


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Menedżer połączeń programu SSIS Excel nie mógł połączyć się ze źródłem

  2. Jak znaleźć max rekordów dla danego zakresu

  3. Dlaczego indeksowanie pełnotekstowe SQL nie zwraca wyników dla słów zawierających #?

  4. Jak przekonwertować liczbę całkowitą na liczbę dziesiętną w SQL Server

  5. Wiele kluczy podstawowych z asp .net mvc 3