EFCore擴展:IQueryable(linq)或sql執行的查詢緩存與清理

来源:http://www.cnblogs.com/skig/archive/2017/01/20/EFCoreExtend_Cache.html
-Advertisement-
Play Games

前言 上一篇講述了執行sql和配置的一些功能,這篇說明IQueryable(linq)或執行sql的查詢緩存與清理,包括擴展到將緩存存儲到Redis中。 擴展類庫源碼: github:https://github.com/skigs/EFCoreExtend 引用類庫: nuget:https:// ...


前言

上一篇講述了執行sql和配置的一些功能,這篇說明IQueryable(linq)或執行sql的查詢緩存與清理,包括擴展到將緩存存儲到Redis中。

擴展類庫源碼:

  github:https://github.com/skigs/EFCoreExtend 

引用類庫:

  nuget:https://www.nuget.org/packages/EFCoreExtend/ 

    PM> Install-Package EFCoreExtend

  查詢緩存引用Redis:

    PM> Install-Package EFCoreExtend.Redis

 

IQueryable(linq)查詢緩存

DbContext:

 1     public class MSSqlDBContext : DbContext
 2     {
 3         protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
 4         {
 5             if (optionsBuilder.IsConfigured == false)
 6             {
 7                 optionsBuilder.UseSqlServer(@"data source=localhost;initial catalog=TestDB;uid=sa;pwd=123;");
 8             }
 9             base.OnConfiguring(optionsBuilder);
10         }
11         public DbSet<Person> Person { get; set; }
12     }
View Code

表實體:

1     [Table(nameof(Person))]
2     public class Person
3     {
4         public int id { get; set; }
5         public string name { get; set; }
6         [Column(TypeName = "datetime")]
7         public DateTime? birthday { get; set; }
8         public int? addrid { get; set; }
9     }
View Code

IQueryable查詢緩存:

1             DbContext db = new MSSqlDBContext();
2             var person = db.Set<Person>();
3             //緩存不過期:參數一為表名(緩存清理的時候有用:根據表名清理緩存)
4             //            參數二緩存過期策略,如果不設置為緩存不過期
5             IReadOnlyList<Person> list = person.Where(l => l.name == "tom1").ListCache(nameof(Person), null);
6             //這行和上面的一樣
7             var list0 = person.Where(l => l.name == "tom1").ListCache<Person, Person>(null);

緩存清理:

1             ////緩存清理
2             //根據指定的IQueryable清理緩存(Person表下的)
3             person.Where(l => l.name == "tom1").ListCacheRemove<Person>();
4             //移除指定緩存類型的所有緩存:List(Person表下的)
5             EFHelper.Services.Cache.ListRemove<Person>();
6             //移除Person表下的所有緩存
7             EFHelper.Services.Cache.Remove<Person>();

查詢緩存期限:

1             //緩存過期
2             var list1 = person.Where(l => l.name == "tom2")
3                 .ListCache(nameof(Person), new QueryCacheExpiryPolicy(TimeSpan.FromMinutes(15)));  //15分鐘
4             //這行和上面的一樣
5             var list11 = person.Where(l => l.name == "tom2")
6                 .ListCache<Person, Person>(TimeSpan.FromMinutes(15));  //15分鐘
7             var list2 = person.Where(l => l.name == "tom3")
8                 .ListCache<Person, Person>(DateTime.Parse("2018-1-1"));  //指定DateTime

緩存期限更新:

1             //緩存期限更新
2             var policy = new QueryCacheExpiryPolicy(TimeSpan.FromMinutes(15), true);  //第二個參數指定每次獲取都更新緩存時間
3             var list3 = person.Where(l => l.name == "tom4").ListCache(nameof(Person), policy);  //15分鐘

其他類型的查詢緩存與清理

 1             DbContext db = new MSSqlDBContext();
 2             var person = db.Set<Person>();
 3             var query = person.Where(l => l.name == "tom1");
 4 
 5             ////FirstOrDefault
 6             var f = query.FirstOrDefaultCache<Person, Person>(TimeSpan.FromSeconds(15));
 7             //根據指定的IQueryable清理緩存(Person表下的)
 8             query.FirstOrDefaultCacheRemove<Person>();
 9             //移除指定緩存類型的所有緩存:FirstOrDefault(Person表下的)
10             EFHelper.Services.Cache.FirstOrDefaultRemove<Person>();
11 
12             ////Count
13             var c = query.CountCache<Person, Person>(TimeSpan.FromSeconds(15));
14             //根據指定的IQueryable清理緩存(Person表下的)
15             query.CountCacheRemove<Person>();
16             //移除指定緩存類型的所有緩存:Count(Person表下的)
17             EFHelper.Services.Cache.CountRemove<Person>();
18 
19             ////LongCount
20             var lc = query.LongCountCache<Person, Person>(TimeSpan.FromSeconds(15));
21             //根據指定的IQueryable清理緩存(Person表下的)
22             query.LongCountCacheRemove<Person>();
23             //移除指定緩存類型的所有緩存:LongCount(Person表下的)
24             EFHelper.Services.Cache.LongCountRemove<Person>();
25 
26             ////其他類型的緩存
27             //參數一:緩存類型,參數二:需要返回的數據
28             query.Cache<Person, int>("sum", () => query.Sum(l => l.id), TimeSpan.FromMinutes(15));
29             query.CacheRemove<Person>("sum");   //清理指定類型下的指定IQueryable的緩存
30             //移除指定緩存類型的所有緩存:sum
31             EFHelper.Services.Cache.Remove<Person>("sum");

 

SQL執行的查詢緩存

 1             DbContext db = new MSSqlDBContext();
 2             string sql = $"select * from {nameof(Person)} where name=@name";
 3             var policy = new QueryCacheExpiryPolicy(TimeSpan.FromMinutes(15));
 4             var pararmModel = new { name = name };
 5 
 6             ////query的sql緩存
 7             IReadOnlyList<Person> list = db.QueryCacheUseModel<Person, Person>(
 8                 sql, pararmModel, null, null, policy);
 9             //根據指定的sql清理緩存(Person表下的)
10             db.QueryCacheRemoveUseModel<Person>(sql, pararmModel, null);
11             //移除query類型的所有緩存(Person表下的)
12             EFHelper.Services.Cache.QueryRemove<Person>();
13 
14 
15             string sql1 = $"select count(*) from {nameof(Person)} where name=@name";
16             ////scalar的sql緩存
17             object val = db.ScalarCacheUseModel<Person>(sql1, pararmModel, null, policy);
18             //根據指定的sql清理緩存(Person表下的)
19             db.ScalarCacheRemoveUseModel<Person>(sql, pararmModel, null);
20             //移除scalar類型的所有緩存(Person表下的)
21             EFHelper.Services.Cache.ScalarRemove<Person>();

使用Redis存放查詢緩存

查詢緩存引用Redis:PM> Install-Package EFCoreExtend.Redis

程式初始化的時候調用:

1             //使用Redis存放查詢緩存
2             EFHelper.ServiceBuilder.AddQueryCacheCreator(sp =>
3                 new RedisQueryCacheCreator("127.0.0.1:6379,allowAdmin=true"))
4                 .BuildServices();   //重新編譯服務

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 我們知道,2016年是雲的時代,各種雲,主流就是docker和openstack,Docker呢確實很火,不少公司都在嘗試,我們也在用,並且全部服務docker化了。個人感受就是坑比較多,我們是一個填坑的過程。 接下來就分享一些不錯的文章,這樣大家可以對docker有更深一步的瞭解。 1、官方文檔: ...
  • 前言 使用普通用戶sudo echo 執行重定向命令的時候提示許可權不夠,已經在/etc/sudoers下做了配置。 www ALL=(ALL) NOPASSWD: /usr/bin/echo # 解決辦法 在使用sudo echo ‘hehe’>/usr/local/index.html的時候,其實 ...
  • Shell模板 ...
  • [root@localhost ~]# root——用戶名 localhost——本地 ~——家目錄 不同用戶不同 #——當前用戶是管理員 $——普通用戶 命令格式: 命令 [選項] [參數] pwd——當前目錄 cd [參數] 進入當前用戶的家 cd ~/cd [Enter] 進入上次目錄 cd ...
  • 大家都知道,現在和以前比起來,互聯網行業、軟體行業已經天差地別了。現在處處都在搞信息化建設,人人都知道互聯網思維。這樣的信息化時代,對於軟體開發者、對於軟體開發公司來說,是一個巨大的機遇。 在門外漢看來,軟體開發是機遇大、成本低,只要叫幾個程式員,就能搞出個軟體公司來。但是,事實情況是這個樣子嗎?本 ...
  • 在webuploader上傳大文件時必須配置一下,不然請求後臺處理程式時,會請求超時。出現404! <system.web> <httpRuntime maxRequestLength="2040000" useFullyQualifiedRedirectUrl="true" executionTi ...
  • 在 Windows Forms 和 WPF 應用中使用 FontAwesome 圖標 ...
  • 在C#中 “\”是特殊字元,要表示它的話需要使用“\\”。由於這種寫法不方便,C#語言提供了@對其簡化。只要在字元串前加上@即可直接使用“\”。所以上面的路徑在C#中應該表示為“Book”,@“\Tmp\Book”,@“C:\Tmp\Book”。 相對路徑使用“/”字元作為目錄的分隔字元,而絕對路徑 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...