【 tulaoshi.com - SQLServer 】
                             
                            在我们的工作中,经常需要连续输入多个文件的数据到SQL Server的表中,有时需要从相同或者不同的目录中,同时将文件中的数据倒入。在这篇文章中,我们将讨论如何同时把一个目录中的文件的数据倒入到SQL Server中。  
    试验环境 
    我们先创建整个试验的环境。创建文件目录“C:MyImport”,和三个文件a.csv、b.csv和c.csv,文件内容如下。同时,在SQL Server中创建一个表用来存放导入的数据。 
        C:MyImporta.csv  
        1, MAK, A9411792711, 3400.25  
        2, Claire, A9411452711, 24000.33  
        3, Sam, A5611792711, 1200.34  
        C:MyImportb.csv  
        11, Rubon, 9671792711, 400.14  
        22, Mike, 9418952711, 4000.56  
        39, Hsu, 75611792511, 1230.00  
        C:MyImportc.csv  
        69, Lucy, 8411992710, 305.11  
        45, Grace, 3413452713, 246.52  
        33, Saint, 5461795716, 1278.70  
        Create Database Bank 
        Go 
        Use Bank 
        go 
        Create table Account 
        ( 
            [ID] int, Name Varchar(100),  
            AccountNo varchar(100), Balance money 
        ) 
        Go 
        Create table logtable  
        ( 
            id int identity(1,1),  
            Query varchar(1000),  
            Importeddate datetime default getdate() 
        )         
    方法 1: XP_CMDSHELL 和BULK INSERT 
    这个方法使用xp_cmdshell和Bulk Insert的SQL命令把一个目录中的文件倒入到SQL Server的表中。 
创建存储过程 
    在数据库中产生这个存储过程,这个存储过程有三个参数:文件路径,文件扩展名和数据库的表名。 
Create procedure usp_ImportMultipleFiles @filepath varchar(500),  
@pattern varchar(100), @TableName varchar(128) 
as 
set quoted_identifier off 
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 ’+@filepath+@pattern +’ /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 tabl