BCP проблемы со специальными символами при вставке таблиц - PullRequest
0 голосов
/ 06 марта 2020

У меня есть текстовый файл со специальными символами

#ID^&^DESCRIPTION^&^DATEINS
1^&^This is a test rec^&^12/23/2019 11:31:48
2^&^A Unique identification number (IČO) ^&^10/21/2019 07:36:48
4^&^Test 3 row known as ÖNACE 2020^&^11/02/2009 07:36:48

Это таблица, которую я создал

CREATE TABLE [dbo].[TESTtbl](
    [id] [int] NOT NULL,
    [desc] [nvarchar](MAX) collate Latin1_General_CI_AS,
    [DATEINS] [datetime] NULL,
 ) 
 ON [PRIMARY]

Я создал файл формата ниже

10.0
3
1       SQLCHAR             0       12      "^&^"      1     cd_val_id                                ""
2       SQLNCHAR            0       0       "^&^"      2     bus_desc                                 SQL_Latin1_General_CP1_CI_AS
3       SQLCHAR             0       24      "\r\n"     3     DateIns                                  ""

Я не вижу правильных символов в таблице для столбца "bus_des c". Как это исправить?

Это команда bcp, которую я использовал

bcp.exe DBNAME.[dbo].[TESTtbl] in "c:\temp\some.txt" -T -f "c:\temp\formatfile.fmt"  -C -S"SERVERNAME\INSTANCENAME" -F2 -t "^&^"  -e "c:\temp\err.txt" -o "c:\temp\bcpout.txt"

1 Ответ

0 голосов
/ 07 марта 2020

Один из способов - загрузить все данные в таблицу и манипулировать ими позже. Пожалуйста, найдите код ниже:

drop table if exists [dbo].[TESTtbl]

CREATE TABLE [dbo].[TESTtbl](
    [id] [int] NOT NULL,
    [desc] [nvarchar](MAX),
    [DATEINS] [datetime] NULL,
 ) 

drop table if exists [dbo].TESTtbl_new

CREATE TABLE [dbo].[TESTtbl_new](
    [desc] [nvarchar](MAX) 
 ) 

declare @cmd nvarchar(100) = 'bcp DBNAME.dbo.[TESTtbl_new] in "FILE_PATH" -T -c -C 65001 -S SERVERNAME\INSTANCENAME'
exec xp_cmdshell @cmd

select * from [TESTtbl_new]

update [TESTtbl_new]
set [desc] = replace([desc], '^&^', '@')    --assuming actual data wouldn't have '@'

;WITH C AS(
SELECT [desc] AS ID
      ,value 
      ,ROW_NUMBER() OVER(PARTITION BY [desc] ORDER BY (SELECT NULL)) as rn
FROM [TESTtbl_new] TT
    CROSS APPLY STRING_SPLIT([desc], '@')t
)
INSERT INTO [TESTtbl]
SELECT [1] AS ID
      ,[2] AS [DESCRIPTION]
      ,[3] AS [DATEINS]
FROM C
PIVOT(
    MAX(VALUE)
    FOR RN IN([1],[2],[3])  
) as PVT
WHERE [1] <> '#ID'

select * from [TESTtbl]

Результат:

Final Result

...