亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Entity?Framework代碼優(yōu)先Code?First入門

 更新時間:2022年06月21日 10:47:32   作者:天方  
這篇文章介紹了Entity?Framework的代碼優(yōu)先模式Code?First,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

CodeFirst是EntityFramework 4.1后新增的一種映射方式,在這種方式下,開發(fā)人員只需要編寫代碼,由ORM框架自動動創(chuàng)建模型和數(shù)據(jù)庫,數(shù)據(jù)庫則可看作類似于XML一樣序列化的方式,非常簡潔(由于開發(fā)人員可以無需關心數(shù)據(jù)庫的具體結構,最初也有叫做CodeOnly的)。

下面就以一個簡單的例子演示一下如何使用CodeFirst。

一、用Nuget添加EntityFramework框架的引用。

二、編寫代碼

    static void Main(string[] args)
    {
        using (var db = new BloggingContext())
        {
            // Create and save a new Blog
            Console.Write("Enter a name for a new Blog: ");
            var name = Console.ReadLine();

            if (!string.IsNullOrEmpty(name))
            {
                var blog = new Blog { Name = name };
                db.Blogs.Add(blog);
                db.SaveChanges();
            }

            // Display all Blogs from the database
            var query = from b in db.Blogs
                        orderby b.Name
                        select b;

            Console.WriteLine("All blogs in the database:");
            foreach (var item in query)
            {
                Console.WriteLine(item.Name);
            }

            Console.WriteLine("Press any key to exit...");
        }
    }

    public class Blog
    {
        public int BlogId { get; set; }
        public string Name { get; set; }
    }

    public class BloggingContext : DbContext
    {
        public DbSet<Blog> Blogs { get; set; }
    }

這里和以前的一點區(qū)別就是增加了一個繼承自DbContext的BloggingContext對象,它表示數(shù)據(jù)庫對象,Blogs則是它的表。如果不關心數(shù)據(jù)庫的存儲方式大可以把它看作一個全局變量。

上述代碼是可以直接執(zhí)行的,雖然這里沒有主動指定數(shù)據(jù)庫,但程序默認使用LocalDb或SqlExpress創(chuàng)建庫,因為我用的是VS2012,就使用了LocalDb創(chuàng)建了庫,并且生成的表的結構如下:

如下是CodeFirst映射數(shù)據(jù)庫的一些基本原則:

數(shù)據(jù)庫名:當沒有顯示設置數(shù)據(jù)連接的時候,默認的數(shù)據(jù)庫是:.\SQLEXPRESS。如果本地沒有SQLEXPRESS,EF會嘗試LocalDb ((localdb)\v11.0) .\SQLEXPRESS 這個數(shù)據(jù)庫包含在VS2012中。數(shù)據(jù)庫的名稱一般是DbContext的"命名空間.類名"

表名:表名默認為模型類名的復數(shù)形式,并且每個表都使用dbo構架創(chuàng)建。這里生成的就是dbo.Lodgings.

主鍵:Code First會默認將以類似Id結尾來命名的屬性當作主鍵,如ID,Id,本例中的DestinationId都自動設置為主鍵。如果該屬性是int類型,Code First會在數(shù)據(jù)庫中默認將該列設置為自增長。

數(shù)據(jù)類型:在SQL Server中,字符串默認映射成nvarchar(max),byte[]映射成varbinary(max),bool映射成bit,decimal映射成decimal(18, 2),float映射成float。同時因為bool,decimal,float等是值類型,不能為給他們分配Null值。所生成的數(shù)據(jù)庫會要求對應的列非空。如Lodgings表中的IsResort

外鍵:當CodeFirst檢測到一對多的映射時,會自動生成相應的外鍵關聯(lián),這個下一節(jié)再介紹。

三、數(shù)據(jù)模型變化的處理

當我們的數(shù)據(jù)結構變化了后,就會出現(xiàn)數(shù)據(jù)模型和數(shù)據(jù)庫不一致的情況。此時運行則會出現(xiàn)如下異常:

未經處理的異常: System.InvalidOperationException: The model backing the 'BloggingContext' context has changed since the database was created. Consider using Code First Migrations to update the database (http://go.microsoft.com/fwlink/?LinkId=238269).

官方給的解決方案如下:Code First Migrations。不過,在開發(fā)過程中,由于數(shù)據(jù)結構變更是很常見的事情,按照這個方案來未免麻煩了點,很多時候我們是采用一種更加簡單粗暴的做法:

System.Data.Entity.Database.SetInitializer(new DropCreateDatabaseIfModelChanges());

把這句話放在程序的最開始。這樣,一旦檢測到數(shù)據(jù)庫有變更,則會重建整個數(shù)據(jù)庫。需要注意的時,由于重建數(shù)據(jù)庫會刪除所有的數(shù)據(jù),過于霸氣。因此不要輕易用于正式版本,使用時最好用DEBUG的宏把它括起來。

四、部署到其它數(shù)據(jù)庫

雖然默認情況下會使用LocalDb或SqlExpress創(chuàng)建數(shù)據(jù)庫非常方便,但實際應用中往往會要把它部署到指定的數(shù)據(jù)庫中的,要指定數(shù)據(jù)庫也非常簡單,只需要在app.config中添加配置即可(原來產生的默認配置不用處理)。

????<connectionStrings>
? ? ? ? <add
? ? ? ? ? ? name="BloggingContext"
? ? ? ? ? ? providerName="System.Data.SqlClient"
? ? ? ? ? ? connectionString="Server=.\SQLEXPRESS;Database=Products;Trusted_Connection=true;"/>
? ? </connectionStrings>

這里一并給一個比較常用的MySql連接的示例:

????<connectionStrings>
????????<add?name="BloggingContext"?providerName="MySql.Data.MySqlClient"
? ?? ?? ?? ??connectionString="server=192.168.10.10;User Id=admin;password=test;database=BloggingContext;"?/>
? ??</connectionStrings>

需要注意的是,如果原來的數(shù)據(jù)庫存在的時候,往往會因為殘留的數(shù)據(jù)和自動映射的不一致而出現(xiàn)無法創(chuàng)建表或其它的異常,最好先把原有的數(shù)據(jù)庫給刪掉。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Visual Studio 2017新版發(fā)布 更強大!

    Visual Studio 2017新版發(fā)布 更強大!

    Visual Studio 2017新版發(fā)布 更強大!對Visual Studio 2017感興趣的小伙伴們可以參考一下
    2017-05-05
  • asp.net Linq to Xml學習筆記

    asp.net Linq to Xml學習筆記

    之前都沒有學習過關于XML文件的操作,由于最近開發(fā)的項目需要用到,開始時學習了原始的XML文件操作方法,看了半天,也看的頭暈眼花,沒學習到真正的用法,后來在同事的推薦下學習了Linq to Xml
    2010-03-03
  • ASP.NET4 GridView的四種排序樣式詳解

    ASP.NET4 GridView的四種排序樣式詳解

    Gridview控件擁有很多不同的CSS樣式屬性設置,包括象CssClass,Font字體,F(xiàn)oreColor,BackColor,BackColor, Width, Height等等,下面為大家介紹下GridView的四種排序樣式
    2014-08-08
  • .NET運行界面上,實現(xiàn)隨意拖動控件的方法

    .NET運行界面上,實現(xiàn)隨意拖動控件的方法

    .NET運行界面上,實現(xiàn)隨意拖動控件的方法,需要的朋友可以參考一下
    2013-03-03
  • .NET Core利用swagger進行API接口文檔管理的方法詳解

    .NET Core利用swagger進行API接口文檔管理的方法詳解

    這篇文章主要給大家介紹了關于.NET Core利用swagger進行API接口文檔管理的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2018-03-03
  • Entity?Framework使用DBContext實現(xiàn)增刪改查

    Entity?Framework使用DBContext實現(xiàn)增刪改查

    這篇文章介紹了Entity?Framework使用DBContext實現(xiàn)增刪改查的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-10-10
  • .NET讀寫Excel工具Spire.Xls使用入門教程(1)

    .NET讀寫Excel工具Spire.Xls使用入門教程(1)

    這篇文章主要為大家詳細介紹了.NET讀寫Excel工具Spire.Xls使用入門教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • Discuz!NT數(shù)據(jù)庫讀寫分離方案詳解

    Discuz!NT數(shù)據(jù)庫讀寫分離方案詳解

    Discuz!NT這個產品在其企業(yè)版中提供了對‘讀寫分離’機制的支持,使對CPU及內存消耗嚴重的操作(CUD)被 分離到一臺或幾臺性能很高的機器上,而將頻繁讀取的操作(select)放到幾臺配置較低的機器上,然后通過‘事務 發(fā)布訂閱機制’,實現(xiàn)了在多個sqlserver數(shù)據(jù)庫之間快速高效同步數(shù)據(jù),從而達到了將‘讀寫請求’按實際負載 情況進行均衡分布的效果。
    2010-06-06
  • 進度條在.net導入Excel時的應用實例

    進度條在.net導入Excel時的應用實例

    這篇文章主要介紹了進度條在.net導入Excel時的應用,以實例形式講述了.net導入Excel時根據(jù)頁面情況顯示進度條的實現(xiàn)方法,非常具有實用價值,需要的朋友可以參考下
    2014-10-10
  • asp.net 獲取客戶端瀏覽器訪問的IP地址的實例代碼

    asp.net 獲取客戶端瀏覽器訪問的IP地址的實例代碼

    本篇文章主要介紹了asp.net 獲取客戶端瀏覽器訪問的IP地址的實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07

最新評論