SQL Server: как мне разграничить эти данные? - PullRequest
0 голосов
/ 27 апреля 2010
declare @mydata nvarchar(4000)    

set @mydata =  '36|0, 77|5, 132|61'

У меня есть эти данные, которые мне нужно внести в таблицу. Таким образом, для Row1 columnA будет 36, а columnB будет 0. Для Row2 columnA будет 77, а columnB будет 5 и т. Д.

Каков наилучший способ сделать это?

Спасибо

Ответы [ 2 ]

1 голос
/ 27 апреля 2010

Если данные находятся в файле, вы должны иметь возможность tp bcp или BULK INSERT, указав терминаторы строк и столбцов

В противном случае вам понадобится вложенная функция разделения

Конечно, вы также можете отправить данные на SQL Server в формате xml

1 голос
/ 27 апреля 2010

Вам нужна разделенная табличная функция. В сети есть множество примеров, например, http://www.sqlteam.com/forums/topic.asp?TOPIC_ID=50648

CREATE FUNCTION dbo.Split
(
    @RowData nvarchar(2000),
    @SplitOn nvarchar(5)
)  
RETURNS @RtnValue table 
(
    Id int identity(1,1),
    Data nvarchar(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
go

declare @mydata nvarchar(4000)     
set @mydata =  '36|0, 77|5, 132|61' 

select
    rowid, [1] as col1, [2] as col2
from
(
    select
        Row.Id as rowid, Col.Id as colid, Col.Data
    from dbo.Split(@mydata, ',') as Row
        cross apply dbo.Split(Row.Data, '|') as Col
) d
pivot
(
    min(d.data)
    for d.colid in ([1], [2])
) pd

Я только что выбрал первую найденную функцию разделения. Я не думаю, что это лучший, но он работает для этого примера.

Выходные данные:

rowi     col1     col2
1   36  0
2   77  5
3   132 61
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...