搜尋
首頁後端開發C#.Net教程Entity Framework自訂分頁效果的實作教學

Entity Framework自訂分頁效果的實作教學

Aug 12, 2017 pm 04:39 PM
framework自訂

這篇文章主要為大家詳細介紹了基於Entity Framework自訂分頁效果,增刪改的通用實現,具有一定的參考價值,有興趣的小夥伴們可以參考一下

簡介

之前寫一個基於Dapper的分頁實現,現在再來寫一個基於Entity Framework的分頁實現,以及增刪改的通用實現。


#還是先上程式碼:https://github.com/jinweijie/EF.GenericRepository

如何運行範例

還是像先前一樣:

1. 先Clone下程式碼,在Database裡面解壓縮Database.7z

2. Attach到Sql Server LocalDB上。如果你用的不是Sql Server的LocalDB,你需要更改App.Config裡的連線字串。

3. Ctrl + F5,執行範例程式。

Repository 基類- 查詢

Common\AbstractRepository.cs 是Repository的基類,實作了增刪改查的一些方法,例如:


public virtual Tuple<IEnumerable<T>, int> Find(Expression<Func<T, bool>> criteria
      , int pageIndex
      , int pageSize
      , string[] asc
      , string[] desc
      , params Expression<Func<T, object>>[] includeProperties)

這個方法是AbstractRepository查詢方法中的一個,用於自訂分頁查詢,其中criteria 為一個表達式,作為查詢的條件,參數pageIndex, pageSize, asc, desc為分頁相關參數;

關於多表(關聯表):

includeProperties為在多表時候,Join相關聯的表。因為EF預設是Lazy Loading,相關聯的表預設不是立即載入的,所以有時候如果寫程式碼不小心,在for迴圈裡就有可能會循環查詢n個字表。用來includeProperties參數,就可以在查詢時候join關聯表。

Repository 基底類別- 增刪改

#AbstractRepository已經用泛型實作了增刪改方法:

public virtual T Create(T entity)
public virtual T Update(T entity)
public virtual T CreateOrUpdate(T entity)
public virtual void Delete(TId id)

#另外,關於transaction的實作,我使用了Unit of Work模式,多個Repository共用一個DBContext,關於UOW,請在Common\UnitOfWork.cs裡找到。

呼叫UOW的時候,基本上類似於這樣:


var uow = new EFUnitOfWork();
var repo = uow.GetLogRepository();

repo.Create(new Log
{
  LevelId = 1,
  Thread = "",
  Location = "Manual Creation",
  Message = "This is manually created log.",
  CreateTime = DateTimeOffset.Now,
  Date = DateTime.Now
});

uow.Commit();

從UnitOfWork得到一個或多個Repository,共享DBContext,做增刪改操作,最後uow統一SaveChanges。

Repository的衍生類別

由於已經有了AbstractRepository,實現了增刪改查的許多方法,所以派生類,例如範例專案裡的LogRepository基本上可以變得很簡單,主要實作一些特定的業務邏輯,在範例專案裡,因為沒有特殊的業務邏輯,所以會很簡單:


public class LogRepository : AbstractRepository<Log, int>
  {
    public LogRepository(EFContext context)
      : base(context)
    {
    }
  }

關於Entity的生成

本人比較喜歡Database First 實現,先設計資料庫,然後用edmx reverse engineering,產生POCO。可以參考Entity目錄下的相關檔案。

當然,如果你喜歡Code First,同樣沒有問題,仍然適用本文的實作。

使用Logging日誌追蹤EF SQL

在使用Entity Framework的時候,最好關心EF所產生的SQL,這樣可以在開發階段發現一些潛在的效能問題,避免在生產環境焦頭爛額:)

在Common\EFContext.cs 裡,有一個配置項EnableTraceSql,如果為true,那麼所以EF產生的SQL將會被nlog記錄下來。我將nlog的日誌配置到了資料庫。也就是說,當你執行範例專案時,每次查詢,都會增加新的日誌記錄,內容為查詢時產生的SQL:

Specification Pattern

在查詢方法裡,有個重載是接受一個ISpecification範例,這樣的實作可以有效的控制業務邏輯,對於寫給被其他人呼叫的介面來說,可以明確的確定查詢參數,例如:


public class LogSearchSpecification : ISpecification<Log>
  {
    public string LevelName { get; set; }
    public string Message { get; set; }
    public Expression<Func<Log, bool>> ToExpression()
    {
      return log => (log.Level.Name == LevelName || LevelName == "") &&
             (log.Message.Contains(Message) || Message == "");
    }

    public bool IsSatisfiedBy(Log entity)
    {
      return (entity.Level.Name == LevelName || LevelName == "") &&
          (entity.Message.Contains(Message) || Message == "");
    }
  }

那麼,呼叫這個查詢方法的程式碼就可以明確知道,我的查詢條件為LevelName和Message,至於LevelName是等於而Message為Like則是在LogSearchSpeficiation裡實現,做到很好的封裝。

以上是Entity Framework自訂分頁效果的實作教學的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
使用C#.NET開發:實用指南和示例使用C#.NET開發:實用指南和示例May 12, 2025 am 12:16 AM

C#和.NET提供了強大的功能和高效的開發環境。 1)C#是一種現代、面向對象的編程語言,結合了C 的強大和Java的簡潔性。 2).NET框架是一個用於構建和運行應用程序的平台,支持多種編程語言。 3)C#中的類和對像是面向對象編程的核心,類定義數據和行為,對像是類的實例。 4).NET的垃圾回收機制自動管理內存,簡化開發者的工作。 5)C#和.NET提供了強大的文件操作功能,支持同步和異步編程。 6)常見錯誤可以通過調試器、日誌記錄和異常處理來解決。 7)性能優化和最佳實踐包括使用StringBuild

C#.NET:了解Microsoft .NET框架C#.NET:了解Microsoft .NET框架May 11, 2025 am 12:17 AM

.NETFramework是一個跨語言、跨平台的開發平台,提供一致的編程模型和強大的運行時環境。 1)它由CLR和FCL組成,CLR管理內存和線程,FCL提供預構建功能。 2)使用示例包括讀取文件和LINQ查詢。 3)常見錯誤涉及未處理異常和內存洩漏,需使用調試工具解決。 4)性能優化可通過異步編程和緩存實現,保持代碼可讀性和可維護性是關鍵。

c#.net的壽命:其持久流行的原因c#.net的壽命:其持久流行的原因May 10, 2025 am 12:12 AM

C#.NET保持持久吸引力的原因包括其出色的性能、豐富的生態系統、強大的社區支持和跨平台開發能力。 1)性能表現優異,適用於企業級應用和遊戲開發;2).NET框架提供了廣泛的類庫和工具,支持多種開發領域;3)擁有活躍的開發者社區和豐富的學習資源;4).NETCore實現了跨平台開發,擴展了應用場景。

掌握C#.NET設計模式:從單胎到依賴注入掌握C#.NET設計模式:從單胎到依賴注入May 09, 2025 am 12:15 AM

C#.NET中的設計模式包括Singleton模式和依賴注入。 1.Singleton模式確保類只有一個實例,適用於需要全局訪問點的場景,但需注意線程安全和濫用問題。 2.依賴注入通過注入依賴提高代碼靈活性和可測試性,常用於構造函數注入,但需避免過度使用導致複雜度增加。

現代世界中的C#.NET:應用和行業現代世界中的C#.NET:應用和行業May 08, 2025 am 12:08 AM

C#.NET在現代世界中廣泛應用於遊戲開發、金融服務、物聯網和雲計算等領域。 1)在遊戲開發中,通過Unity引擎使用C#進行編程。 2)金融服務領域,C#.NET用於開發高性能的交易系統和數據分析工具。 3)物聯網和雲計算方面,C#.NET通過Azure服務提供支持,開發設備控制邏輯和數據處理。

C#.NET開發人員社區:資源和支持C#.NET開發人員社區:資源和支持May 06, 2025 am 12:11 AM

C#.NET開發者社區提供了豐富的資源和支持,包括:1.微軟的官方文檔,2.社區論壇如StackOverflow和Reddit,3.GitHub上的開源項目,這些資源幫助開發者從基礎學習到高級應用,提升編程技能。

C#.NET優勢:功能,好處和用例C#.NET優勢:功能,好處和用例May 05, 2025 am 12:01 AM

C#.NET的優勢包括:1)語言特性,如異步編程簡化了開發;2)性能與可靠性,通過JIT編譯和垃圾回收機制提升效率;3)跨平台支持,.NETCore擴展了應用場景;4)實際應用廣泛,從Web到桌面和遊戲開發都有出色表現。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具