1

我在一个网络表单上有 5 个 FileUpload 控件。我有两个 sql server 表...

Tbl_ClaimDetails

SrNo | Remark | BrMkrdt

Tbl_ClaimImages

SrNo | Img | Id | ImgName

第一个文件上传控制是强制性的。例如,如果用户选择要上传的 3 个文件,则第一个图像文件用于Tbl_ClaimDetails通过存储过程将数据插入(SrNo inTbl_ClaimDetails是身份),我将使用SCOPE_IDENTITY(). 我将此 SCOPE_IDENTITY() 值存储在变量中lastid

现在我正在使用另一个存储过程将数据Tbl_ClaimImages与 lastid 一起插入到第一个图像中。

if (file1.ContentLength > 0 && (u1 != null || u1 != 0))
{
                Stream fs = file1.InputStream;
                BinaryReader br = new BinaryReader(fs);
                Byte[] bytes = br.ReadBytes((Int32)fs.Length);

//store procedure inserts data in tbl_claimdetails and return SCOPE_IDENTITY()
                lastid = dbo.ExecProc1(claim.Remark,  claim.BrMkrdt);
//another stored procedure inserts data in tbl_ClaimImages
                dbo.insert(bytes, lastid, file1.FileName);    
             count++;
}

if (file2.ContentLength > 0 && (u1 != null || u1 != 0))
{
                Stream fs = file2.InputStream;
                BinaryReader br = new BinaryReader(fs);
                Byte[] bytes = br.ReadBytes((Int32)fs.Length);                
                dbo.insert(bytes, lastid, file1.FileName);    
             count++;
}// and so on till file5

这种方法运行良好。我没有任何错误或问题,但我想知道是否有比这更好的方法?如您所见,我正在执行两个不同的存储过程,用于在给定的表中插入值。插入值的存储过程Tbl_ClaimDetails在开始时只执行一次,然后我一次又一次地执行另一个存储过程以Tbl_ClaimImages根据用户上传的图像数量插入值。是否有可能在一次执行中使用一个存储过程来完成所有这些工作?还是有更好的方法?

4

1 回答 1

1

为了减少调用次数并一次性完成任务,我认为只有一种方法假设您拥有 MS-SQL Server 2008+ 数据库并且使用 ADO.Net SQL 客户端没有限制。

  1. 在 SQL Server 中创建两个 TableType,两个表的架构相同,即 Tbl_ClaimDetails 和 Tbl_ClaimImages
  2. 创建一个具有两个参数的存储过程,即您创建的 TableTypes。
  3. 存储过程可以有Merge语句,可以帮助您轻松地插入父子表。
  4. 在 .Net 中创建两个 DataTable,它们应该具有与底层数据库表相同的结构,对于文件,您可以使用 byte[] [试一试]。
  5. 使用 Sql.Structured 数据类型并将这两个数据表传递给创建的存储过程。

您还可以从代码项目中找到如何在 SQL 中使用表类型的示例代码。

使用这种方法,您只需要一次调用具有完整数据结构的 SQL。我希望这将帮助您满足您正在查看的内容。

于 2013-08-30T10:47:59.497 回答