我有一个File Repository库,用于处理将文件保存到服务器上的过程。除了保存物理文件外,还会记录数据库条目。
以下是插入方法。
public DataFile InsertFile(string fileName, byte[] fileBytes)
{
File.WriteAllBytes(Path.Combine(FileRepPath, fileName), fileBytes);
DataFile dataFile = NewDataFile(
fileName,
fileBytes.Length
);
try
{
using (MyEntities context = new MyEntities())
{
context.DataFiles.Add(dataFile);
context.SaveChanges();
}
}
catch (Exception)
{
File.Delete(Path.Combine(FileRepPath, fileName));
throw;
}
return dataFile;
}
如果数据库更新失败,那么我想从服务器中删除该文件。我这样做是通过捕获上下文操作中发生的任何异常并删除文件(并重新抛出错误以使其冒泡)。
这是正确的做法吗?我应该抓住更具体的例外吗?
答案 0 :(得分:1)
我建议您使用TransactionScope对象为您管理此任务。实现IEnlistmentNotification接口的每个组件都可以参与TransactionScope
的两阶段提交。
提交将要求获得MS-DTC的服务,但它将确保保存全部或全部。 MS-DTC用于协调跨多个异构资源的事务结果。
以下是一些Microsoft文章: