使用文件名参数批量插入 [重复]

Posted

技术标签:

【中文标题】使用文件名参数批量插入 [重复]【英文标题】:Bulk Insert with filename parameter [duplicate] 【发布时间】:2011-11-10 12:29:09 【问题描述】:

我需要将数千个数据文件加载到 SQL Server 表中。 所以我写了一个存储过程,它只接收一个参数——文件名。 但是..以下不起作用..“编译器”抱怨@FileName参数..它只需要纯字符串..像'file.txt'。 提前致谢。

伊兰。

BULK INSERT TblValues
FROM @FileName
WITH 
(
FIELDTERMINATOR =',',
ROWTERMINATOR ='\n'
)

【问题讨论】:

您是在寻找纯 SQL 解决方案,还是能够使用 C#/VB? 谢谢保罗!我已经找到了***.com/questions/4050790/… @IIan,如果你有答案,请关闭问题,下次在提问之前搜索类似问题。 【参考方案1】:

The syntax for BULK INSERT statement 是:

BULK INSERT 
   [ database_name. [ schema_name ] . | schema_name. ] [ table_name | view_name ] 
      FROM 'data_file' 
     [ WITH 

因此,文件名必须是字符串常量。 解决问题请使用动态SQL:

DECLARE @sql NVARCHAR(4000) = 'BULK INSERT TblValues FROM ''' + @FileName + ''' WITH ( FIELDTERMINATOR ='','', ROWTERMINATOR =''\n'' )';
EXEC(@sql);

【讨论】:

这正是我所做的。谢谢! ***.com/questions/4050790/… SQL 注入怎么样?

以上是关于使用文件名参数批量插入 [重复]的主要内容,如果未能解决你的问题,请参考以下文章

MySql批量插入时,如何不插入重复的数据

nodejs mysql批量插入重复密钥更新

使用重复键更新在 MariaDB 中批量插入

MySQL 批量插入,如何不插入重复数据?

带有快速数组参数的节点mysql批量插入

mysql批量插入时,如何不插入重复数据