处理实体框架清理的SaveChanges()异常

时间:2013-05-17 05:42:59

标签: c# .net entity-framework exception entity-framework-4

我有一个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;
}

如果数据库更新失败,那么我想从服务器中删除该文件。我这样做是通过捕获上下文操作中发生的任何异常并删除文件(并重新抛出错误以使其冒泡)。

这是正确的做法吗?我应该抓住更具体的例外吗?

1 个答案:

答案 0 :(得分:1)

我建议您使用TransactionScope对象为您管理此任务。实现IEnlistmentNotification接口的每个组件都可以参与TransactionScope的两阶段提交。

提交将要求获得MS-DTC的服务,但它将确保保存全部或全部。 MS-DTC用于协调跨多个异构资源的事务结果。

以下是一些Microsoft文章: