EF7創建模型值生成篇

来源:https://www.cnblogs.com/YataoFeng/archive/2023/03/07/17187786.html
-Advertisement-
Play Games

Github Actions 是 Github 提供的一種持續集成(CI)和持續部署(CD)工具,可以自動化代碼開發、測試、構建和部署的過程。它可以在代碼倉庫中通過配置文件來定義工作流程(Workflow),包括觸發事件、執行任務和處理結果等。這些工作流程可以與Github倉庫的其他功能(如Issu ...


在 EF7 中,生成的值是非常重要的,因為它們決定了資料庫表中的數據。在本文中,我們將以人員為例,使用 Fluent API 展示所有 EF7 生成值的功能。
我們先來看一下人員表的屬性:

public class Person
{
    public Guid Id { get; set; }
    public string Name { get; set; }
    public int NameLength { get; set; }
    public int Age { get; set; }
    public DateTime Birthday { get; set; }
    public DateTime CreationTime { get; set; }
    public DateTime LastUpdated { get; set; }
}

在EF7中,我們可以使用Fluent API來配置表的屬性。下麵,我們將展示所有生成值的功能,並提供相應的代碼示例。

預設值

預設值是指當實體對象的屬性沒有設置值時,將使用的值。使用 HasDefaultValue 方法設置預設值:

builder.Property(p => p.CreationTime).HasDefaultValue(DateTime.Now); 

還可以使用 SQL 表達式為屬性指定一個預設值:

builder.Property(e => e.CreationTime).HasDefaultValueSql("getdate()");

計算列

計算列是指在資料庫中創建的一列,該列的值是由一系列計算表達式生成的。在 EF7 中,我們可以使用 HasComputedColumnSql 方法來創建計算列。例如,我們要將 Person 實體的 FullName 屬性設置為由 FirstName 和 LastName 屬性計算得出的值:

builder.Property(p => p.FullName)
    .HasComputedColumnSql("[FirstName] + ' ' + [LastName]");

HasComputedColumnSql 方法還有一個 stored 參數,當指定為 true 時,EF7 將在資料庫中創建一個存儲的計算列。這在插入新記錄時,計算列的值將由資料庫計算並存儲在該列中,而不是每次查詢時重新計算。以下代碼將 Age 和 NameLength 屬性設置為存儲的計算列:

builder.Property(e => e.Age)
    .HasComputedColumnSql("[CreationTime].[Year] - [Birthday].[Year]", stored: true);

builder.Property(p => p.NameLength)
    .HasComputedColumnSql("LEN([LastName]) + LEN([FirstName])", stored: true);

顯示配置值生成

顯示配置值生成是指在 EF7 中明確指定生成的值。在 EF7 中,我們可以使用 ValueGeneratedOnAdd 方法允許我們指定屬性的值在插入新記錄時自動生成。例如,我們可以使用以下代碼為 id 屬性指定自增值:

builder.Property(p => p.Id).ValueGeneratedOnAdd(); 

有些需求是修改,我們可以使用 ValueGeneratedOnAddOrUpdate 方法允許我們指定屬性的值在插入或更新記錄時自動生成。例如,我們可以使用以下代碼為 LastUpdated 屬性指定預設值,併在插入或更新記錄時自動生成 LastUpdated 的值:

builder.Property(e => e.LastUpdated).HasDefaultValueSql("getdate()")
    .ValueGeneratedOnAddOrUpdate();

自定義值生成

在某些情況下,我們可能希望在插入新記錄時使用自定義的值生成策略。

builder.Property(p => p.Id)
    .HasValueGenerator<GuidValueGenerator>(); // 使用自定義的值生成器

public class GuidValueGenerator : ValueGenerator<Guid>
{
    public override bool GeneratesTemporaryValues => false;
    public override Guid Next(EntityEntry entry)
    {
        return Guid.NewGuid(); // 生成Guid值
    }
}

一般來說,EF資料庫提供程式已經幫我們實現好了Guid的演算法。使用顯示值生成就可以,不需要自定義。
見這篇文章:《EF7資料庫提供者的自定義值生成器》

替代值生成

在 EF7 中,當我們向資料庫中插入一條新記錄或更新現有記錄時,如果某些屬性的值未設置,則 EF7 會根據其配置生成預設值。然而,有時候我們可能希望在保存更改後保留屬性的當前值而不是使用預設值,或者在屬性的值未設置時拋出異常。
PropertySaveBehavior 枚舉表示屬性在保存更改時的行為。它有以下三個狀態:

  1. Save:屬性值應該被保留。
  2. Ignore:屬性值應該被忽略。
  3. Throw:如果屬性值未設置,則應該拋出異常。

SetAfterSaveBehavior保存更改前、SetBeforeSaveBehavior保存更改後方法允許我們為特定屬性設置這些行為。
例如,我們可以使用以下代碼為 LastUpdated 屬性,雖然指定預設值是當前修改時間。但在保存更改前,未設置預設值,則拋出異常,而不會使用預設值:

builder.Property(b => b.LastUpdated).HasDefaultValue(DateTime.Now)
        .ValueGeneratedOnAddOrUpdate()
        .Metadata.SetAfterSaveBehavior(PropertySaveBehavior.Throw);

無值生成

無值生成是指在 EF7 中不生成任何值。在 EF7 中,我們可以使用 ValueGeneratedNever 方法來設置無值生成。例如,我們要將 Person 實體的 Email 屬性設置為不生成任何值:

builder.Property(p => p.Email).ValueGeneratedNever();

總結

在本文中,我們介紹了 EF7 中可用的各種生成值選項,並以人員為例演示瞭如何使用 Fluent API 配置這些選項。使用生成值選項可以使我們更方便地處理資料庫相關任務。例如,我們可以使用預設值、計算列和自動生成值等選項來簡化我們的代碼,提高代碼的可讀性和可維護性。
在使用這些選項時,我們需要瞭解每個選項的用途和適用場景,以便選擇合適的選項。在本文中,我們介紹了以下選項:

  • HasDefaultValue: 指定屬性的預設值
  • HasDefaultValueSql: 使用 SQL 表達式指定屬性的預設值
  • HasComputedColumnSql: 將屬性指定為存儲的計算列
  • HasComputedColumnSql stored: 將屬性指定為計算列並將其存儲在資料庫中
  • ValueGeneratedOnAdd: 指定屬性的值在插入新記錄時自動生成
  • ValueGeneratedOnAddOrUpdate: 指定屬性的值在插入或更新記錄時自動生成
  • 自定義值生成
  • 替代值生成
  • 無值生成

通過使用這些選項,我們可以輕鬆地配置我們的實體模型,並使其更符合我們的業務需求。


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

-Advertisement-
Play Games
更多相關文章
  • 來源:blog.csdn.net/qq_41698074/article/details/108502976 前言 雖然 stream在 Java8 中就已經被引入,但是大多數人卻沒有去使用這個十分有用的特性,本文就通過介紹幾個通過使用stream讓代碼更簡潔、可讀,來讓你瞭解stream的方便之處 ...
  • 連接層 最上層是一些客戶端和鏈接服務,包含本地sock 通信和大多數基於客戶端/服務端工具實現的類似於 TCP/IP的通信。主要完成一些類似於連接處理、授權認證、及相關的安全方案。在該層上引入了線程 池的概念,為通過認證安全接入的客戶端提供線程。同樣在該層上可以實現基於SSL的安全鏈接。服務 器也會 ...
  • Whay need the CMake? 如果只是構建一個只有一個main.cpp的小型項目,那麼確實不需要CMake, 直接GCC、G++編譯,或者寫個build.sh腳本即可, 不需要把簡單的問題搞複雜化。 $ g++ main.cpp -o cmake_hello 但是如果你的項目分了很多模塊 ...
  • 使用記憶體對齊機制優化結構體性能,妙啊! 可以簡單理解為:將對齊繫數小的欄位,儘可能放在一起,儘量減少空白填充。 掌握了記憶體對齊機制後,結構體Struct的優化,調整下欄位順序,效果立竿見影。記憶體對齊其實就是典型的空間換時間的方式,來達到優化的目的。牢記對齊原則,對實際場景進行分析,減少空白填充。 ...
  • 昨天在群里看到有小伙伴問,Java里如何解析SQL語句然後格式化SQL,是否有現成類庫可以使用? 之前TJ沒有做過這類需求,所以去研究了一下,並找到了一個不過的解決方案,今天推薦給大家,如果您正要做類似內容,那就拿來試試,如果暫時沒需求,就先瞭解收藏(技多不壓身)。 JSqlParser JSqlP ...
  • 本文已經收錄到Github倉庫,該倉庫包含電腦基礎、Java基礎、多線程、JVM、資料庫、Redis、Spring、Mybatis、SpringMVC、SpringBoot、分散式、微服務、設計模式、架構、校招社招分享等核心知識點,歡迎star~ Github地址:https://github.c ...
  • 自動化測試環境的搭建 :一、安裝 selenium: 安裝方式一: pip install -U selenium 安裝方式二: 手動安裝 selenium: 1、安裝python包,選擇全部組件(pip、安裝過程中配置環境變數)解壓selenium-4.8.2.tar.gz,然後用cmd進入解壓目 ...
  • 代碼覆蓋率(Code coverage)是指在軟體測試中測試用例執行時覆蓋的代碼量與總代碼量的比例。代碼覆蓋率是軟體測試中一個重要的指標,它對於保障軟體質量、提高軟體可靠性和可維護性具有許多好處:發現代碼缺陷、提高代碼的可維護性、確保代碼的正確性和優化測試用例質量等。 我們常用的 IDE,Visua ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...