3

我有一个看起来像这样的简单模型:

public class ImageFile
{
    [Key]
    [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
    public int Id { get; set; }
    public ImageMeta Meta { get; set; }
    public string FileName { get; set; }
    public DateTime DateUploaded { get; set; }
    public int Width { get; set; }
    public int Height { get; set; }
}

有什么方法可以添加某种“OnDelete”事件挂钩,以便每当通过db.Images.Remove(imageFile);或任何其他方式删除模型时,我都可以删除关联的文件?

4

1 回答 1

3

您可以覆盖SaveChanges上下文的方法以连接到删除实体。

public class GalleryContext : DbContext
{
     public override int SaveChanges()
     {
          var deletedImages = ChangeTracker.Entries()
              .Where(e => e.State == EntityState.Deleted && e.Entity is ImageFile)
              .Select(e => e.Entity).Cast<ImageFile>();

          foreach(var image in deletedImages)
          {
              // delete file here or call a method on image
          }

          return base.SaveChanges();
     }
}
于 2012-09-05T05:53:59.133 回答