EFSecondLevelCache
=======
Entity Framework .x Second Level Caching Library.
二级缓存是一个查询缓存。EF命令的结果将存储在缓存中,这相同的EF命令将从缓存中检索数据,而不是执行它们对数据库了。
使用方法:
- 设置缓存失效通过重写SaveChanges方法防止过期写道
namespace EFSecondLevelCache.TestDataLayer.DataLayer
{
public class SampleContext : DbContext
{
// public DbSet<Product> Products { get; set; }
public SampleContext()
: base("connectionString1")
{
}
//重写 SaveChanges
public override int SaveChanges()
{
return SaveAllChanges(invalidateCacheDependencies: true);
}
public int SaveAllChanges(bool invalidateCacheDependencies = true)
{
var changedEntityNames = getChangedEntityNames();
var result = base.SaveChanges();
if (invalidateCacheDependencies)
{
new EFCacheServiceProvider().InvalidateCacheDependencies(changedEntityNames);
}
return result;
}
//修改、删除、添加数据时缓存失效
private string[] getChangedEntityNames()
{
return this.ChangeTracker.Entries()
.Where(x => x.State == EntityState.Added ||
x.State == EntityState.Modified ||
x.State == EntityState.Deleted)
.Select(x => System.Data.Entity.Core.Objects.ObjectContext.GetObjectType(x.Entity.GetType()).FullName)
.Distinct()
.ToArray();
}
}
}
有时你不想缓存失效时非更新NumberOfViews等重要性质。
在这些情况下,试着SaveAllChanges(invalidateCacheDependencies:false),之前更新数据。
- 然后正常查询缓存的结果:
var products = context.Products.Include(x => x.Tags).FirstOrDefault();
我们可以使用新的“缓存()的扩展方法:
var products = context.Products.Include(x => x.Tags).Cacheable().FirstOrDefault(); // Async methods are supported too.
注意:
适合使用全球网站的查询缓存设置,公共的文章或评论列表
而不是经常改变,私人或特定的数据,每个用户。
如果一个页面需要身份验证,其数据不应该被缓存。
开源地址:
https://github.com/VahidN/EFSecondLevelCache