2016-09-21 72 views
1

我想每天导入txt文件到SQL Server 2008表,我想将其自动化插入许多.txt文件(每天)到SQL Server 2008表

所以在步骤:
1 - 我收到每日2个文件,名称为hazem.log.date和hazem.log.date2
2-我需要一种方法来每天自动导入它们
3-我将使用该作业,但应使用哪个命令或查询在这种情况下?

+1

您可以尝试SQL工作 –

+0

我怀疑纯sql可以读取一般文件。 – reporter

+0

SQL作业都ok自动化吧..我应该用什么来查询每日一次导入的文件夹中的所有文件? – Zomzomzom

回答

1

尝试通过SQLServer的就业机会低于运行..

BULK INSERT dbo.ImportTest 
FROM 'C:\ImportData.txt' --replace name of your files 
WITH (FIELDTERMINATOR =',', FIRSTROW = 2) 

你也可以使用

bcp dbo.ImportTest in 'C:\ImportData.txt' -T -SserverName\instanceName 

对于多发files..you能做到这样的..

1.创建一个存储过程的第一个..

Create procedure usp_ImportMultipleFilesBCP @servername varchar(128), 
@DatabaseName varchar(128), @filepath varchar(500), @pattern varchar(100), 
@TableName varchar(128) 
as 
declare @query varchar(1000) 
declare @max1 int 
declare @count1 int 
Declare @filename varchar(100) 
set @count1 =0 
create table #x (name varchar(200)) 
set @query ='master.dbo.xp_cmdshell "dir '[email protected][email protected] +' /b"' 
insert #x exec (@query) 
delete from #x where name is NULL 
select identity(int,1,1) as ID, name into #y from #x 
drop table #x 
set @max1 = (select max(ID) from #y) 
--print @max1 
--print @count1 
--select * from #y 
While @count1 <= @max1 
begin 
set @[email protected]+1 
set @filename = (select name from #y where [id] = @count1) 
set @Query ='bcp "'+ @databasename+'.dbo.'[email protected] + '" 
    in "'+ @[email protected]+'" -S' + @servername + ' -T -c -r\n -t,' 
set @Query = 'MASTER.DBO.xp_cmdshell '+ "'"+ @query +"'" 
--print @query 
EXEC (@query) 
insert into logtable (query) select @query 
end 

2.Now上述SP运行导入所需分机的所有文件

Exec usp_ImportMultipleFilesBCP 'SQL','Bank','c:\Myimport\','*.csv','Account'--table account 

注:
您将需要启用Xp_cmdshell

参考文献:
https://www.mssqltips.com/sqlservertip/1207/different-options-for-importing-data-into-sql-server/
http://www.databasejournal.com/features/mssql/article.php/3325701/Import-multiple-Files-to-SQL-Server-using-T-SQL.htm

+0

这是确定一个文件的..但如果它们是什么10,我想一次导入呢? – Zomzomzom

+0

@Zomzomzom:看udpated – TheGameiswar

+0

哪些变量应该被改变,那么这是很长的查询? – Zomzomzom