Entity Framework 教程

一、概述

Entity Framework(實體框架)是一個ORM(對象關係映射)框架,它允許開發人員通過將業務對象映射到數據庫中的表,來實現對數據庫進行操作。它是一個開源框架,由Microsoft維護和開發。Entity Framework不僅提供了數據訪問的解決方案,還支持LINQ(語言集成查詢)等功能,使得編寫數據庫訪問代碼變得更加簡單和直接。

二、基礎操作

使用Entity Framework來操作數據庫,需要進行以下基本步驟:

1、創建一個繼承自DbContext的類,並提供數據庫連接字符串。DbContext是應用程序和數據庫之間交換數據的主要類。它表示一個特定數據庫的上下文。

下面是一個簡單的DbContext的示例:


public class MyDbContext : DbContext
{
    public MyDbContext() : base("name=MyConnectionString")
    {
    }
 
    public DbSet Categories { get; set; }
    public DbSet Products { get; set; }
}

2、創建模型。模型是可持久化數據的實體類。它們映射到數據庫的表,在模型中定義的屬性則對應於表中的列,為每個模型類設置主鍵是必選的。


public class Category
{
    public int Id { get; set; }
    public string Name { get; set; }
    
    public virtual ICollection<Product> Products { get; set; }
}
    
public class Product
{
    public int Id { get; set; }
    //省略其它屬性
 
    public int CategoryId { get; set; }
    public virtual Category Category { get; set; }
}

3、執行CRUD操作。數據庫的增刪改查操作可以通過DbContext來實現。以查詢為例,下面是一個使用LINQ進行查詢並返回結果的示例:


using (var context = new MyDbContext())
{
    var products = from p in context.Products
                   where p.CategoryId == 1
                   select p;
 
    foreach (var product in products)
    {
        Console.WriteLine(product.Name);
    }
}

三、數據遷移

數據遷移是指修改實體類及其屬性,從而對數據庫架構進行更改。它允許開發人員在不刪除數據庫並保持數據完整性的同時,對應用程序和數據庫架構進行升級。

1、安裝Entity Framework遷移工具。在NuGet包管理器控制台中,執行以下命令:


Install-Package EntityFramework
Install-Package EntityFramework.Tools

2、創建遷移腳本。在終端輸入以下命令:


dotnet ef migrations add <migration name>

其中,<migration name>是自定義的遷移腳本名稱。這個命令會將所有與上一個遷移腳本不同的模型更改寫入新的遷移腳本中,並將其應用於數據庫。

3、通過遷移腳本更新數據庫。在終端輸入以下命令:


dotnet ef database update

四、分頁技巧

分頁是常見的需求,以下是一些常見的分頁技巧:

1、使用Skip()和Take()方法。Skip()和Take()方法允許在從數據庫檢索和處理結果之前跳過一些行,並限制返回的行數。下面是一個簡單的示例,該示例從數據庫中返回第11-20行的數據:


int pageSize = 10;
int pageNumber = 2;
 
var query = context.Products.OrderBy(p => p.Name)
                .Skip((pageNumber - 1) * pageSize)
                .Take(pageSize)
                .ToList();

2、使用HasNextPage和HasPreviousPage屬性統計物品頁數。以下是一個示例方法,該方法接受當前頁碼、每頁的元素數和總記錄數,並將總頁數、下一頁和上一頁標誌作為out參數輸出:


public static void CalculatePageInfo(int currentPage, int itemsPerPage, int totalItems, out int totalPages, out bool hasNextPage, out bool hasPreviousPage)
{
    totalPages = totalItems / itemsPerPage;
    if (totalItems % itemsPerPage != 0)
    {
        totalPages++; // 如果有餘數,則增加一頁
    }
 
    hasNextPage = (currentPage  1);
}

五、存儲過程和函數

Entity Framework也支持存儲過程和函數。以下是一些例子:

1、使用SqlQuery方法調用存儲過程。SqlQuery方法允許執行任意的SQL語句,下面是一個簡單的存儲過程示例:


var categoryId = new SqlParameter("@categoryId", 1); // 存儲過程需要參數categoryId
 
var products = context.Database.SqlQuery<Product>("EXEC GetProductsByCategoryId @categoryId", categoryId).ToList();

2、使用FunctionAttribute屬性和In/Out/Return等修飾符聲明函數。以下是一個簡單的函數示例,該函數可以接受輸入參數和返回值:


[DbFunction("MyNamespace", "MyScalarFunction")]
public static int MyScalarFunction(int input)
{
    throw new NotSupportedException(); // 空實現,因為我們不應該在代碼中調用函數,而應該將其用在LINQ表達式中
}

然後,可以將它添加到LINQ查詢中:


var query = from p in context.Products
            select new
            {
                Id = p.Id,
                Name = p.Name,
                CategoryId = p.CategoryId,
                CategoryName = MyScalarFunction(p.CategoryId) // 使用MyScalarFunction
            };

六、並發控制

在多個線程和進程同時訪問數據庫時,可能會發生並發更新。為了解決這個問題,Entity Framework支持樂觀並發控制和悲觀並發控制。

1、樂觀並發控制。樂觀並發控制假定在任何給定時間,每個實體都具有獨立的版本,並且在保存實體時進行檢查。如果實體版本與數據庫中的版本不匹配,則表示實體已被其他用戶更新並拋出異常。


var product = context.Products.Find(id);
product.Name = "NewName";
 
try
{
    context.SaveChanges();
}
catch (DbUpdateConcurrencyException ex)
{
    // 必須獲取數據庫中的實體以更新本地緩存
    ex.Entries.Single().Reload();
}

2、悲觀並發控制。悲觀並發控制使用鎖定機制,在對實體進行修改時阻止其他會話的訪問。以下是一個示例,使用SELECT FOR UPDATE語句將數據行鎖定:


using (var context = new MyDbContext())
{
    using (var dbContextTransaction = context.Database.BeginTransaction())
    {
        try
        {
            var product = context.Products.SqlQuery("SELECT * FROM dbo.Products WITH (UPDLOCK, ROWLOCK) WHERE Id = @id", new SqlParameter("@id", id)).Single();
 
            product.Name = "NewName";
 
            context.SaveChanges();
 
            dbContextTransaction.Commit();
        }
        catch (Exception ex)
        {
            dbContextTransaction.Rollback();
        }
    }
}

七、總結

Entity Framework提供了一種簡單的方法來訪問和操作數據庫。從基礎操作、數據遷移、分頁技巧、存儲過程和函數以及並發控制等方面,本文介紹了Entity Framework的常見用法,並提供了代碼示例。使用Entity Framework時,請考慮數據量和性能問題,並選擇最適合自己的實現方式。

原創文章,作者:RKSY,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/131113.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
RKSY的頭像RKSY
上一篇 2024-10-03 23:43
下一篇 2024-10-03 23:43

相關推薦

  • MQTT使用教程

    MQTT是一種輕量級的消息傳輸協議,適用於物聯網領域中的設備與雲端、設備與設備之間的數據傳輸。本文將介紹使用MQTT實現設備與雲端數據傳輸的方法和注意事項。 一、準備工作 在使用M…

    編程 2025-04-29
  • Python3.6.5下載安裝教程

    Python是一種面向對象、解釋型計算機程序語言。它是一門動態語言,因為它不會對程序員提前聲明變量類型,而是在變量第一次賦值時自動識別該變量的類型。 Python3.6.5是Pyt…

    編程 2025-04-29
  • Deepin系統分區設置教程

    本教程將會詳細介紹Deepin系統如何進行分區設置,分享多種方式讓您了解如何規劃您的硬盤。 一、分區的基本知識 在進行Deepin系統分區設置之前,我們需要了解一些基本分區概念。 …

    編程 2025-04-29
  • 寫代碼新手教程

    本文將從語言選擇、學習方法、編碼規範以及常見問題解答等多個方面,為編程新手提供實用、簡明的教程。 一、語言選擇 作為編程新手,選擇一門編程語言是很關鍵的一步。以下是幾個有代表性的編…

    編程 2025-04-29
  • Qt雷達探測教程

    本文主要介紹如何使用Qt開發雷達探測程序,並展示一個簡單的雷達探測示例。 一、環境準備 在開始本教程之前,需要確保你的開發環境已經安裝Qt和Qt Creator。如果沒有安裝,可以…

    編程 2025-04-29
  • 猿編程python免費全套教程400集

    想要學習Python編程嗎?猿編程python免費全套教程400集是一個不錯的選擇!下面我們來詳細了解一下這個教程。 一、課程內容 猿編程python免費全套教程400集包含了從P…

    編程 2025-04-29
  • Python煙花教程

    Python煙花代碼在近年來越來越受到人們的歡迎,因為它可以讓我們在終端里玩煙花,不僅具有視覺美感,還可以通過代碼實現動畫和音效。本教程將詳細介紹Python煙花代碼的實現原理和模…

    編程 2025-04-29
  • 使用Snare服務收集日誌:完整教程

    本教程將介紹如何使用Snare服務收集Windows服務器上的日誌,並將其發送到遠程服務器進行集中管理。 一、安裝和配置Snare 1、下載Snare安裝程序並安裝。 https:…

    編程 2025-04-29
  • Python畫K線教程

    本教程將從以下幾個方面詳細介紹Python畫K線的方法及技巧,包括數據處理、圖表繪製、基本設置等等。 一、數據處理 1、獲取數據 在Python中可以使用Pandas庫獲取K線數據…

    編程 2025-04-28
  • Python語言程序設計教程PDF趙璐百度網盤介紹

    Python語言程序設計教程PDF趙璐百度網盤是一本介紹Python語言編程的入門教材,本文將從以下幾個方面對其進行詳細闡述。 一、Python語言的特點 Python語言屬於解釋…

    編程 2025-04-28

發表回復

登錄後才能評論