EFSecondLevelCache ======= Entity Framework 6.x Second Level Caching Library. 二級緩存是一個查詢緩存。EF命令的結果將存儲在緩存中,這相同的EF命令將從緩存中檢索數據,而不是執行它們對數據庫了。 使用方法: 1- 設置緩存失效通過重寫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),之前更新數據。 2- 然后正常查詢緩存的結果: 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