我想每天導入txt文件到SQL Server 2008表,我想將其自動化插入許多.txt文件(每天)到SQL Server 2008表
所以在步驟:
1 - 我收到每日2個文件,名稱爲hazem.log.date和hazem.log.date2
2-我需要一種方法來每天自動導入它們
3-我將使用該作業,但應使用哪個命令或查詢在這種情況下?
我想每天導入txt文件到SQL Server 2008表,我想將其自動化插入許多.txt文件(每天)到SQL Server 2008表
所以在步驟:
1 - 我收到每日2個文件,名稱爲hazem.log.date和hazem.log.date2
2-我需要一種方法來每天自動導入它們
3-我將使用該作業,但應使用哪個命令或查詢在這種情況下?
嘗試通過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
這是確定一個文件的..但如果它們是什麼10,我想一次導入呢? – Zomzomzom
@Zomzomzom:看udpated – TheGameiswar
哪些變量應該被改變,那麼這是很長的查詢? – Zomzomzom
您可以嘗試SQL工作 –
我懷疑純sql可以讀取一般文件。 – reporter
SQL作業都ok自動化吧..我應該用什麼來查詢每日一次導入的文件夾中的所有文件? – Zomzomzom