在asp.net中使用单个sql查询上传多个文件

时间:2013-02-05 17:03:19

标签: asp.net sql sql-server sql-server-2008

我正在使用文件上传控件..在asp.net ..首先在临时目录中存储文件 然后在用户点击保存后我将文件从temp移动到我想要的位置。 问题是我必须使用循环并为我的插入查询进行5次数据库访问以插入5条记录。但我想为此编写单个查询。 我知道我可以发送我的图像名称以及图像路径逗号分隔。但由于我没有足够的sql知识,我不知道如何在SQL中拆分逗号分隔文件然后使用光标插入它们。所以我要求一个在这里给我写一个示例查询。我可以继续。

1 个答案:

答案 0 :(得分:0)

使用可以将数据集作为xml传递给存储过程,在存储过程中,您可以使用openXML一次性插入多行

用于将数据集对象作为xml传递给存储过程的C#代码

         ...................................

    DataSet ds = new DataSet(); // assume dataset has records(in table object)
    string xmlString = ds.GetXml();

    SqlCommand cmd = new SqlCommand("your procedure name", "your Connection object");
    cmd.Parameters.Add(new SqlParameter("@XmlString",xmlString);
             ...................................

存储过程,使用openXML批量插入

      ...................................

  DECLARE @XMLDocPointer INT    
  EXEC sp_xml_preparedocument @XMLDocPointer OUTPUT, @XmlString    

   INSERT INTO Employee
   (Name, Email, PhoneNo)    
   SELECT Name,Email,PhoneNo   
   FROM OPENXML(@XMLDocPointer,'/ROOT/DATA',2)    
   WITH  (Name VARCHAR(50),-- '@Name',     
         Email VARCHAR(50),-- '@Email',     
         PhoneNo VARCHAR(50) --'@PhoneNo')     

   EXEC sp_xml_removedocument @XMLDocPointer    
        ...................................

阅读此内容以获取完整示例 http://www.codeproject.com/Articles/417181/Bulk-Insertion-of-Data-Using-Csharp-DataTable-and

=============================================== ====================

如果你在sql中寻找拆分字符串 那么下面是你需要在sqlserver中创建的sql函数

create function f_split(@SourceSql varchar(8000),@StrSeprate varchar(10))
returns @temp 
table(a varchar(100))
begin    
 declare @i int    
 set @SourceSql=rtrim(ltrim(@SourceSql)) 
 set @i=charindex(@StrSeprate,@SourceSql)    
 while @i>=1    
 begin        
  insert @temp values(left(@SourceSql,@i-1))        
  set @SourceSql=substring(@SourceSql,@i+1,len(@SourceSql)-@i)        
  set @i=charindex(@StrSeprate,@SourceSql)    
 end    
 if @SourceSql<>'\'       
 insert @temp values(@SourceSql)    
 return 
end
go

以及如何致电

select * from dbo.f_split('1,2,3,4,5',',')

然后使用光标你可以插入所有

对于拆分功能,请参阅此帖子http://social.msdn.microsoft.com/forums/en-US/transactsql/thread/4126a010-6885-4eb0-b79c-c798c90edb85