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