FluentAPI詳細用法

来源:https://www.cnblogs.com/giftmm/archive/2018/07/14/9308676.html
-Advertisement-
Play Games

設置主鍵 modelBuilder.Entity<x>().HasKey(t => t.Name); 設置聯合主鍵 modelBuilder.Entity<x>().HasKey(t =>new{t.Name,t.ID} ); 取消資料庫欄位標識(取消自動增長) modelBuilder.Entit ...


  • 設置主鍵
    modelBuilder.Entity<x>().HasKey(t => t.Name);
  • 設置聯合主鍵
    modelBuilder.Entity<x>().HasKey(t =>new{t.Name,t.ID} );
  • 取消資料庫欄位標識(取消自動增長)
    modelBuilder.Entity<x>().Property(t=>t.Id).HasDatabaseGeneratedOption(DatabaseGeneratedOption.None);
  • 設置資料庫欄位標識(自動增長)
    modelBuilder.Entity<Teacher>().Property(t =>t.Id).HasDatabaseGeneratedOption(DatabaseGeneratedOption.Identity);
  • 設置欄位最大長度
    modelBuilder.Entity<ClassA>().Property(t => t.Name).HasMaxLength(100);
  • 設置欄位為必需
    modelBuilder.Entity<ClassA>().Property(t =>t.Id).IsRequired();
  • 屬性不映射到資料庫
    modelBuilder.Entity<ClassA>().Ignore(t => t.A);
  • 將屬性指定資料庫列名:
    modelBuilder.Entity<ClassA>() .Property(t => t.A) .HasColumnName("A_a");
  • 級聯刪除(資料庫預設是不級聯刪除的)
    modelBuilder.Entity<Course>().HasRequired(t => t.Department).WithMany(t => t.Courses).HasForeignKey(d => d.DepartmentID).WillCascadeOnDelete();
  • 設置為Timestamp
    modelBuilder.Entity<OfficeAssignment>() .Property(t => t.Timestamp) .IsRowVersion();
  • 表1對0..1(Instructor實體可以包含零個或一個OfficeAssignment)
    modelBuilder.Entity<OfficeAssignment>().HasRequired(t => t.Instructor).WithOptional(t => t.OfficeAssignment);
  • 表1對1
    modelBuilder.Entity<Instructor>().HasRequired(t => t.OfficeAssignment).WithRequiredPrincipal(t => t.Instructor);
  • 表1對n(Department為主表)
    modelBuilder.Entity<Staff>() .HasRequired(c => c.Department) .WithMany(t => t.Staffs)
  • 指定外鍵名(指定表Staff中的欄位DepartmentID為外鍵)
    modelBuilder.Entity<Staff>() .HasRequired(c => c.Department) .WithMany(t => t.Staffs) .Map(m => m.MapKey("DepartmentID"));
  • 表n對n
    modelBuilder.Entity<Course>()
    .HasMany(t => t.Instructors)
    .WithMany(t => t.Courses)
  • 表n對n指定連接表名及列名
    modelBuilder.Entity<Course>()
    .HasMany(t => t.Instructors)
    .WithMany(t => t.Courses)
    .Map(m =>
    {
    m.ToTable("CourseInstructor");
    m.MapLeftKey("CourseID");
    m.MapRightKey("InstructorID");
    });




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

-Advertisement-
Play Games
更多相關文章
  • 推薦加【QQ48200036】專業盜取微信密碼,破解微信密碼,查詢微信聊天記錄,不成功不收費!!!! 近些年,國人的生活水平不斷提高,多數人使用上了智能手機,手機上也往往安裝著微信。微信在人們的生活中扮演著日益重要的角色。微信安全使用不僅僅涉及個人信息的安全性,同時還會影響財產是否有保障。多數瞭解的 ...
  • 作為核心的IoC 作為一種解耦的方式,一些IoC框架就成了項目了核心。比如蔣金楠的VideoMall與陳青陽的Byteart Retail項目都是使用Unity。而ABP則是使用Castle。 Register與Resolve Register與Reslove是IoC基本功能,向容器中註類型對應關係 ...
  • Web應用程式中包含大量的樣式(css)和腳本(js)文件,這些文件的引用、管理和發佈有很多解決方案。在Asp.Net MVC應用程式中,大家最熟悉的解決方案應屬Microsoft.AspNet.Web.Optimization這個package。這個package的使用也挺方便,對我來說,它依賴太 ...
  • .Net Core 使用 System.Drawing.Common 部署到CentOS上遇到的問題 ...
  • 在我們寫程式的時候,經常會需要判斷數據的是空值還是null值,基本上十個方法函數,八個要做這樣的判斷,因此我們很有必要拓展出來一個類來做監控,在這裡我們使用一個簡單地,可拓展的第三方組件:Ardalis.GuardClauses在這裡首先提一點,一般我們的一旦給一個實體類或者集合類初始化了之後,其值 ...
  • ASP.NET Core程式現在變得如同控制台(Console)程式一般,同樣通過Main方法啟動整個應用。而Main方法要做的事情很簡單,創建一個WebHostBuilder類,調用其Build方法生成一個WebHost類,最後啟動之。 實現代碼一目瞭然: 要想探尋其內部究竟做了哪些操作,則需要調 ...
  • 摘自:http://www.cnblogs.com/nianming/archive/2012/11/07/2757997.html Entity Framework Code First的預設行為是使用一系列約定將POCO類映射到表。然而,有時候,不能也不想遵循這些約定,那就需要重寫它們。重寫預設 ...
  • Entity Framework Code First與數據表之間的映射方式有兩種實現:Data Annotation和Fluent API。本文中採用創建Product類為例來說明tity Framework Code First屬性映射約定的具體方式。 1. 表名及所有者 在預設約定的情況下,E ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...