如何从 .t​​xt 文件导入数据以填充 SQL Server 中的表

Art*_*ira 1 sql t-sql sql-server csv flat-file

每天都有一个PPE.txt包含客户数据的文件,以分号分隔并且始终具有相同的布局,这些文件存储到特定的文件目录中。

每天有人必须根据此更新我们数据库中的特定表PPE.txt

我想通过 SQL 脚本自动化这个过程

我认为的解决方案是通过脚本将数据从该.txt文件导入到创建的表中,然后执行更新。

到目前为止我所拥有的是

IF EXISTS (SELECT 1 FROM Sysobjects WHERE name LIKE 'CX_PPEList_TMP%')
   DROP TABLE CX_PPEList_TMP
GO

CREATE TABLE CX_PPEList_TMP  
(
    Type_Registy CHAR(1),
    Number_Person INTEGER,
    CPF_CNPJ VARCHAR(14),
    Type_Person CHAR(1),
    Name_Person VARCHAR(80),
    Name_Agency VARCHAR(40),
    Name_Office VARCHAR(40),
    Number_Title_Related INTEGER,
    Name_Title_Related VARCHAR(80)
)

UPDATE Table1
SET SN_Policaly_Exposed = 'Y'
WHERE Table1.CD_Personal_Number = CX_PPEList_TMP.CPF_CNPJ
  AND Table1.SN_Policaly_Exposed = 'N'

UPDATE Table1
SET SN_Policaly_Exposed = 'N'
WHERE Table1.CD_Personal_Number NOT IN (SELECT CX_PPEList_TMP.CPF_CNPJ 
                                        FROM CX_PPEList_TMP)
  AND Table1.SN_Policaly_Exposed = 'Y'
Run Code Online (Sandbox Code Playgroud)

我知道我没有给予太多,但那是因为我还没有太多。

我想通过脚本CX_PEPList_TMPPEP.txt文件中的数据填充临时表,这样我就可以执行这个脚本来更新我的数据库。但是我不知道我可以使用的任何类型的命令,也没有在我的研究中找到。

提前致谢!

Had*_*adi 5

使用 OPENROWSET

您可以使用OPENROWSET选项读取文本文件(首先您必须启用即席查询)

使用 Microsoft 文本驱动程序

SELECT * FROM OPENROWSET('MSDASQL',
'Driver={Microsoft Text Driver (*.txt; *.csv)};
DefaultDir=C:\Docs\csv\;',
'SELECT * FROM PPE.txt')
Run Code Online (Sandbox Code Playgroud)

使用 OLEDB 提供程序

SELECT 
    * 
FROM 
OPENROWSET
        ('Microsoft.ACE.OLEDB.12.0','Text;Database=C:\Docs\csv\;IMEX=1;','SELECT * 
FROM PPE.txt') t
Run Code Online (Sandbox Code Playgroud)

使用批量插入

您可以将文本文件数据导入临时表并从中更新数据:

BULK INSERT dbo.StagingTable
FROM 'C:\PPE.txt'
WITH 
  (
    FIELDTERMINATOR = ';', 
    ROWTERMINATOR = '\n' 
  )
Run Code Online (Sandbox Code Playgroud)