MyDAL - .ListAsync() 使用

来源:https://www.cnblogs.com/Meng-NET/archive/2018/12/26/10179385.html
-Advertisement-
Play Games

索引: 目錄索引 一.API 列表 .ListAsync() .ListAsync<M>() 如: .ListAsync<AgentInventoryRecord>() , 用於 單表/多表連接 查詢. .ListAsync<VM>() 如: .ListAsync<AgentVM>() , 用於 單 ...


索引:

目錄索引

一.API 列表

  .ListAsync()

  .ListAsync<M>()

    如: .ListAsync<AgentInventoryRecord>() , 用於 單表/多表連接 查詢. 

  .ListAsync<VM>()

    如: .ListAsync<AgentVM>() , 用於 單表 查詢.

  .ListAsync<T>(Expression<Func<M, T>> columnMapFunc)

    如: .ListAsync(it => it.Name) , 用於 單表 單列 查詢.

    或者: 

      .ListAsync(agent => new AgentVM
                  {
                      XXXX = agent.Name,
                      YYYY = agent.PathId
                  })  , 用於 單表 多列 查詢.

  .ListAsync<T>(Expression<Func<T>> columnMapFunc)

    如:  .Queryer(out Agent agent1, out AgentInventoryRecord record1)

      ... ...

      .ListAsync(() => agent1.CreatedOn)   , 用於 多表連接 單列 查詢.

    或者: .Queryer(out Agent agent12, out AgentInventoryRecord record12)

        ... ...

       .ListAsync(() => new AgentVM
                  {
                      nn = agent12.PathId,
                      yy = record12.Id,
                      xx = agent12.Id,
                      zz = agent12.Name,
                      mm = record12.LockedCount
                  })  , 用於 多表連接 多列 查詢.

二.API 單表-便捷 方法 舉例

  1. 單表 單列 多條 便捷方法 

1             var res7 = await Conn.ListAsync<Agent, string>(it => it.Name.StartsWith(""), it => it.Name);

    生成的 SQL 如下

1 select `Name`
2 from `Agent`
3 where  `Name` like  @Name__1;

  2. 單表 多列 多條 便捷方法

1        var date = DateTime.Parse("2018-08-20");
2 
3             var res3 = await Conn.ListAsync<AlipayPaymentRecord, AlipayPaymentRecordVM>(it => it.CreatedOn >= date,
4                 it => new AlipayPaymentRecordVM
5                 {
6                     TotalAmount = it.TotalAmount,
7                     Description = it.Description
8                 });

    生成的 SQL 如下:

1 select     `TotalAmount` as TotalAmount,
2         `Description` as Description
3 from `AlipayPaymentRecord`
4 where  `CreatedOn`>=@CreatedOn__1;

  3. 單表 VM 多條 便捷方法

1             var date = DateTime.Parse("2018-08-20");
2 
3             var res2 = await Conn.ListAsync<AlipayPaymentRecord, AlipayPaymentRecordVM>(it => it.CreatedOn >= date);

    生成 SQL 如下:

1 select     `Id`,
2     `CreatedOn`,
3     `TotalAmount`,
4     `Description`,
5     `CanceledOn`
6 from `AlipayPaymentRecord`
7 where  `CreatedOn`>=@CreatedOn__1;

  4. 單表 M 多條 便捷方法

1             var date = DateTime.Parse("2018-08-20");
2 
3             var res1 = await Conn.ListAsync<AlipayPaymentRecord>(it => it.CreatedOn >= date);

    生成 SQL 如下:

1 select *
2 from `AlipayPaymentRecord`
3 where  `CreatedOn`>=@CreatedOn__1;

三.API 單表-完整 方法 舉例

  1. 單表 單列 多條 完整方法

1             var res2 = await Conn
2                 .Queryer<Agent>()
3                 .Where(it => it.AgentLevel == AgentLevel.DistiAgent)
4                 .ListAsync(it => it.Name);

    生成 SQL 如下:

1 select `Name`
2 from `Agent`
3 where  `AgentLevel`=@AgentLevel__1;

   2.單表 多列 多條 完整方法

1             var res5 = await Conn
2                 .Queryer<Agent>()
3                 .Where(it => it.AgentLevel == AgentLevel.DistiAgent)
4                 .ListAsync(agent => new AgentVM
5                 {
6                     XXXX = agent.Name,
7                     YYYY = agent.PathId
8                 });

    生成 SQL 如下

1 select     `Name` as XXXX,
2     `PathId` as YYYY
3 from `Agent`
4 where  `AgentLevel`=@AgentLevel__1;

  3.單表 VM 多條 完整方法

 1             var testQ5 = new WhereTestModel
 2             {
 3                 CreatedOn = DateTime.Now.AddDays(-30),
 4                 StartTime = WhereTest.CreatedOn,
 5                 EndTime = DateTime.Now,
 6                 AgentLevelXX = AgentLevel.DistiAgent,
 7                 ContainStr = "~00-d-3-1-"
 8             };
 9             var res5 = await Conn
10                 .Queryer<Agent>()
11                 .Where(it => it.CreatedOn >= testQ5.StartTime)
12                 .ListAsync<AgentVM>();

    生成 SQL 如下

1 select     `Id`,
2     `CreatedOn`,
3     `UserId`,
4     `PathId`,
5     `Name`,
6     `Phone`
7 from `Agent`
8 where  `CreatedOn`>=@CreatedOn__1;

  4. 單表 M 多條 完整方法

1             var start = WhereTest.CreatedOn.AddDays(-10);
2 
3             var res2 = await Conn
4                 .Queryer<BodyFitRecord>()
5                 .Where(it => it.CreatedOn >= start)
6                 .ListAsync();

    生成 SQL 如下:

1 select *
2 from `BodyFitRecord`
3 where  `CreatedOn`>=@CreatedOn__1;

四.API 多表連接-完整 方法 舉例

  1.多表連接 單列 多條 完整方法

1             var res1 = await Conn
2                 .Queryer(out Agent agent1, out AgentInventoryRecord record1)
3                 .From(() => agent1)
4                     .InnerJoin(() => record1)
5                         .On(() => agent1.Id == record1.AgentId)
6                 .Where(() => agent1.AgentLevel == AgentLevel.DistiAgent)
7                 .ListAsync(() => agent1.CreatedOn);

    生成 SQL 如下

1 select agent1.`CreatedOn`
2 from `Agent` as agent1 
3     inner join AgentInventoryRecord as record1
4         on agent1.`Id`=record1.`AgentId`
5 where  agent1.`AgentLevel`=@AgentLevel__4;

  2.多表連接 多列 多條 完整方法

 1             var res12 = await Conn
 2                 .Queryer(out Agent agent12, out AgentInventoryRecord record12)
 3                 .From(() => agent12)
 4                     .InnerJoin(() => record12)
 5                         .On(() => agent12.Id == record12.AgentId)
 6                 .Where(() => record12.CreatedOn >= WhereTest.CreatedOn)
 7                 .ListAsync(() => new AgentVM
 8                 {
 9                     nn = agent12.PathId,
10                     yy = record12.Id,
11                     xx = agent12.Id,
12                     zz = agent12.Name,
13                     mm = record12.LockedCount
14                 });

    生成 SQL 如下

1 select     agent12.`PathId` as nn,
2     record12.`Id` as yy,
3     agent12.`Id` as xx,
4     agent12.`Name` as zz,
5     record12.`LockedCount` as mm
6 from `Agent` as agent12 
7     inner join AgentInventoryRecord as record12
8         on agent12.`Id`=record12.`AgentId`
9 where  record12.`CreatedOn`>=@CreatedOn__4;

  3.多表連接 M 多條 完整方法

1             var res1 = await Conn
2                 .Queryer(out Agent agent1, out AgentInventoryRecord record1)
3                 .From(() => agent1)
4                     .InnerJoin(() => record1)
5                         .On(() => agent1.Id == record1.AgentId)
6                 .Where(() => agent1.CreatedOn >= WhereTest.CreatedOn.AddDays(-60))   
7                 .ListAsync<AgentInventoryRecord>();

    生成 SQL 如下

1 select record1.`*`
2 from `Agent` as agent1 
3     inner join AgentInventoryRecord as record1
4         on agent1.`Id`=record1.`AgentId`
5 where  agent1.`CreatedOn`>=@CreatedOn__4;

 

 

 

 

                                         蒙

                                    2018-12-26 15:25 周三

 


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

-Advertisement-
Play Games
更多相關文章
  • 運行結果 ...
  • 本節將在第四節基礎上介紹如何實現IdentityServer4從資料庫獲取User進行驗證,並對Claim進行許可權設置。 一、新建Web API資源服務,命名為ResourceAPI (1)新建API項目,用來進行user的身份驗證服務。 (2)配置埠為5001 安裝Microsoft.Entit ...
  • 上節以對話形式,大概說了幾種客戶端授權模式的原理,這節重點介紹Hybrid模式在MVC下的使用。且為實現IdentityServer4從資料庫獲取User進行驗證,並對Claim進行許可權設置打下基礎(第五節介紹)。 本節內容比較多,且涉及一、二節的內容,如有不懂,可先熟悉一、二節知識。 一、新建授權 ...
  • C 中關於增強類功能的幾種方式 本文主要講解如何利用C 語言自身的特性來對一個類的功能進行豐富與增強,便於拓展現有項目的一些功能。 拓展方法 擴展方法 被定義為靜態方法,通過實例方法語法進行調用。方法的第一個參數指定該方法作用於哪個類型,並且該參數以 this 修飾符為首碼。僅當使用 using 指 ...
  • 使用System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile進行MD5加密時,會出現已過時 ...
  • 1. IsAssignableFrom實例方法 判斷一個類或者介面是否繼承自另一個指定的類或者介面。 輸出結果: IDog was inherited from IAnimalDog was inherited from IAnimalDog was inherited from IDogCate ...
  • 最近把項目更新到了ASP.Net Core 2.2,發佈之後發現在IIS下使用SQLite資料庫不行了,報異常說不能打開資料庫。"unable to open database file",奇了個怪了。照理說這個不是許可權就是路徑錯了,許可權直接加了Everyone也無濟於事,後來換成絕對路徑就可以了,... ...
  • 開發人員之所以花費大量時間來重點設計控制器和模型對象,是因為在這些領域中,精心編寫的整潔代碼是開發一個可維護Web應用程式的基礎。 3.1 視圖的作用 視圖的職責是向用戶提供用戶界面。當控制器針對被請求的URL執行完合適的邏輯後,就將要顯示的內容委托給視圖。 不像基於文件的Web框架,比如ASP.N ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...