.net core Entity Framework 與 EF Core


重點講 Entity Framework Core !

(一)Entity Framework

           它是適用於.NET 的對象關系映射程序 (ORM),現在的EF6已經是久經沙場,並經歷重重磨難,獲得一致認可的數據訪問技術(原來加 Title 也挺有意思的,哈哈哈)。

           作為 ORM,EF6 降低了關系方面和面向對象的方面之間的阻抗不匹配,使開發人員能夠使用表示應用程序域的強類型 .NET 對象來編寫應用程序,該應用程序可與存儲在關系數據庫中的數據交互,同時使開發人員無需再編寫大部分的數據訪問“管道”代碼。這是微軟官方吹牛逼的原話,但也很好理解。

           那基於 EF6 可以實現很多 ORM 的熱門的一些功能:    

    • 不依賴於任何 EF 類型的 POCO (Plain Old CLR Object) 實體類的映射
    • 自動更改跟蹤
    • 標識解析和工作單元
    • 預先、延遲和顯式加載
    • 使用 LINQ(語言集成查詢)轉換強類型查詢
    • 豐富的映射功能,可支持:
      • 一對一、一對多和多對多關系
      • 繼承(每個層次結構一張表、每個類型一張表和每個具體類一張表)
      • 復雜類型
      • 存儲過程
    • 通過可視化設計器創建實體模型。
    • 通過編寫代碼創建實體模型的“Code First”體驗。
    • 既可從現有數據庫生成模型,然后手動編輯,也可從頭開始創建模型,然后用於生成新的數據庫。
    • 與 .NET Framework 應用程序模型(包括 ASP.NET)集成,並通過數據綁定與 WPF 和 WinForms 集成。
    • 基於 ADO.NET 的數據庫連接和可用於連接到 SQL Server、Oracle、MySQL、SQLite、PostgreSQL、DB2 等的眾多提供程序。

           相信很多人都使用過 VS 中 EF 設計器,我以前用得比較多,主要就是在項目中創建的:

    • 項目->添加新項...

    • 選擇數據左側的菜單,然后ADO.NET 實體數據模型;

    • 用生成的 Model 作為名稱,然后單擊確定;

    • 這將啟動實體數據模型向導;

    • 選擇從數據庫生成單擊下一步;

    • 選擇連接到第一個部分中創建的數據庫中,直接用生成的 LibraryEntities 作為名稱的連接字符串和單擊下一步;

    • 選擇好實體框架 6.x ,下一步;

    • 再單擊表導入的所有表並單擊完成旁邊的復選框,點擊完成。

    • 反向工程過程完成后,新的模型就添加到了項目,並直接打開了實體框架設計器

 

            那么現在已經創建完了實體模型。在創建的過程當中,已經幫我們建好了數據類型,生成了表的映射還有存儲過程的映射,這賊爽了,點幾下就搞定了,接着就可以進行增刪改查了(具體怎么做,這里就不詳解了)。

            EF設計器中,我們同樣可以操作表,更新表的字段,再通過正向工程,可以更新數據庫中的表。

            PS:使用 Code First 生成的實體,比EF設計器生成的要干凈,但是也失去了正向工程的功能。

(二)Entity Framework Core

           它是輕量化、可擴展、開源和跨平台版的常用 Entity Framework 數據訪問技術。可用作對象關系映射程序 (ORM),以便於 .NET 開發人員能夠使用 .NET 對象來處理數據庫,這樣就不必經常編寫大部分數據訪問代碼了。

           EF Core 則完全進行了重寫,包含許多 EF6 沒有的新功能,但還是缺少 EF6 中最高級的一些映射功能。

           那如果要通過 VS 進行反向工程的話,需要安裝 PMC 工具,而且這個工具是僅限於VS使用的。當然也還有一些非常棒的代碼生成工具,比如 Code Smith。

           使用PMC生成實體過程:

    • 打開VS的程序包管理控制台

    • 在程序包管理器控制台(PMC)工具中使用命令 Scaffold-DbContext 來進行反向工程。

    Scaffold - DbContext 'Data Source=.;Initial Catalog=Library;integrated security=true' Microsoft.EntityFrameworkCore.SqlServer

           當出入命名直接回車后,會在項目的根目錄下生成文件。當然,你也可以在 Scaffold-DbContext 命令中加入指定的生成路徑等設置命令的。

            這個跟用EF中用 Code First 生成文件是一個毛樣的結果。下圖就是 Code First 生成的。

            當然,他們生成的代碼還是有區別的。我們來看看 Scaffold-DbContext 命令生成的三個文件的代碼:

           1、LibraryContext.cs

    public partial class LibraryContext : DbContext
    {
        public LibraryContext()
        {
        }

        public LibraryContext(DbContextOptions<LibraryContext> options)
            : base(options)
        {
        }

        public virtual DbSet<Books> Books { get; set; }
        public virtual DbSet<Categories> Categories { get; set; }

        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            if (!optionsBuilder.IsConfigured)
            {
                optionsBuilder.UseSqlServer("Data Source=.;Initial Catalog=Library;integrated security=true");
            }
        }

        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            modelBuilder.HasAnnotation("ProductVersion", "2.2.3-servicing-35854");

            modelBuilder.Entity<Books>(entity =>
            {
                entity.ToTable("books");

                entity.Property(e => e.Id)
                    .HasColumnName("id")
                    .ValueGeneratedNever();

                entity.Property(e => e.Author)
                    .IsRequired()
                    .HasColumnName("author")
                    .HasMaxLength(50);

                entity.Property(e => e.Cateid).HasColumnName("cateid");

                entity.Property(e => e.Createtime)
                    .HasColumnName("createtime")
                    .HasColumnType("datetime");

                entity.Property(e => e.Isdel).HasColumnName("isdel");

                entity.Property(e => e.Name)
                    .IsRequired()
                    .HasColumnName("name")
                    .HasMaxLength(50);

                entity.HasOne(d => d.Cate)
                    .WithMany(p => p.Books)
                    .HasForeignKey(d => d.Cateid)
                    .OnDelete(DeleteBehavior.ClientSetNull)
                    .HasConstraintName("FK_books_categories");
            });

            modelBuilder.Entity<Categories>(entity =>
            {
                entity.ToTable("categories");

                entity.Property(e => e.Id)
                    .HasColumnName("id")
                    .ValueGeneratedNever();

                entity.Property(e => e.Cascadeid)
                    .IsRequired()
                    .HasColumnName("cascadeid")
                    .HasMaxLength(20);

                entity.Property(e => e.Createtime)
                    .HasColumnName("createtime")
                    .HasColumnType("datetime");

                entity.Property(e => e.Fid).HasColumnName("fid");

                entity.Property(e => e.Isdel).HasColumnName("isdel");

                entity.Property(e => e.Name)
                    .IsRequired()
                    .HasColumnName("name")
                    .HasMaxLength(50);
            });
        }
    }

           2、Categories.cs

    public partial class Categories
    {
        public Categories()
        {
            Books = new HashSet<Books>();
        }

        public int Id { get; set; }
        public int Fid { get; set; }
        public string Name { get; set; }
        public string Cascadeid { get; set; }
        public DateTime Createtime { get; set; }
        public bool Isdel { get; set; }

        public virtual ICollection<Books> Books { get; set; }
    }

           3、Books.cs

    public partial class Books
    {
        public int Id { get; set; }
        public int Cateid { get; set; }
        public string Name { get; set; }
        public string Author { get; set; }
        public DateTime Createtime { get; set; }
        public bool Isdel { get; set; }

        public virtual Categories Cate { get; set; }
    }

            通過上面可以看到,它們已經生成好了映射。但是,如果要映射存儲過程的話,EF Core 是不支持的。

 (三)它們的區別

            EF Core 提供了在 EF6 中不會實現的新功能(如備選鍵、批量更新以及 LINQ 查詢中的混合客戶端/數據庫評估。 但由於它是一個新代碼庫,所以會缺少一些 EF6 中的功能。這也是正常的,但是它還在不斷的完善!

            EF Core 是更現代、可擴展的輕量級實體框架版本,與 EF6 的功能和優點非常相似。如果功能與需求都匹配的話,可以優先考慮使用 EF Core 的。至少性能擺在那里!

            下面引用官方的圖片,展示它們在功能上的比較:

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM