Sqlserver
 sql >> Teknologi Basis Data >  >> RDS >> Sqlserver

sql server membagi nilai yang dipisahkan koma menjadi kolom

Selesaikan masalah ini secara dinamis, gunakan DSQL untuk menambahkan lebih banyak kolom dalam hasil yang sesuai.

--create split function
CREATE FUNCTION [dbo].[SO_Split]
(
    @List nvarchar(2000),
    @SplitOn nvarchar(5)
) 
RETURNS @RtnValue table
(

    Id int identity(1,1),
    Value nvarchar(100)
)
AS 
BEGIN
While (Charindex(@SplitOn,@List)>0)
Begin
Insert Into @RtnValue (value)
Select
    Value = ltrim(rtrim(Substring(@List,1,Charindex(@SplitOn,@List)-1)))
    Set @List =Substring(@List,Charindex(@SplitOn,@List)+len(@SplitOn),len(@List))
End
    Insert Into @RtnValue (Value)
    Select Value = ltrim(rtrim(@List))
    Return
END

--below is the dynamic solution for this problem
declare @sql nvarchar(3000) = 'select *'
declare @cnt int = 1
declare @rowNum int = (select max(a) from (select(select max(id) as id_max from dbo.so_split(mul_query,'*')) as a from #test) as b)

while(@cnt <= @rowNum)
begin
    set @sql = @sql + N', ISNULL((select value from dbo.so_split(mul_query,''*'') where id = '+cast(@cnt as nvarchar(5))+N'),''1'')'
    set @cnt = @cnt + 1
end

set @sql = @sql + N' from #test'

exec sp_executesql @sql

Hasilnya terlampir di bawah.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Perbaiki Msg 8116 "Tanggal tipe data argumen tidak valid untuk argumen 1 fungsi substring" di SQL Server

  2. Bisakah saya mengaktifkan aign_dup_key untuk kunci utama?

  3. Pilih kolom dari satu tabel berdasarkan nama kolom dari tabel lain

  4. Masuk ke Microsoft SQL Server Kesalahan:18456

  5. Cara menggunakan aspnet_regsql.exe