中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

EF6 秘籍 2th:實體數據建模基礎 (九)切分一個實體到多張表

發布時間:2020-08-11 10:06:43 來源:網絡 閱讀:643 作者:tancfeng 欄目:編程語言

問題:

    有2個或更多的表共享相同的主鍵,現在需要使用單個實體映射這些表。

解決方案:

    數據庫圖表:

EF6 秘籍 2th:實體數據建模基礎 (九)切分一個實體到多張表

    使用代碼優先的方式建模。

    1、添加ADO.NET實體數據模型,命名模型為EF6CodeFirstRecipesContext,選擇空代碼優先模型。

    2、將生成的EF6CodeFirstRecipesContext類修改為EF6RecipesContext類。

    3、修改app.config中的連接字符串參數。

     4、添加POCO實體類Product。代碼如下:

    using System.ComponentModel.DataAnnotations;
    using System.ComponentModel.DataAnnotations.Schema;
    public class Product
    {
        [Key]
        [DatabaseGenerated(DatabaseGeneratedOption.None)]
        public int SKU { get; set; }
        public string Description { get; set; }
        public decimal Price { get; set; }
        public string ImageURL { get; set; }
    }

    5、在EF6RecipesContext類中添加如下屬性:

public DbSet<Product> Products { get; set; }

    6、在重寫的OnModelCreating方法中添加如下代碼:

    modelBuilder.Entity<Product>()
                .Map(m =>
                {
                    m.Properties(p => new { p.SKU, p.Description, p.Price });
                    m.ToTable("Product", "Chapter2");
                })
                .Map(m =>
                {
                    m.Properties(p => new { p.SKU, p.ImageURL });
                    m.ToTable("ProductWebInfo", "Chapter2");
                });

    具體過程可參見上一節內容。如果需要直接使用上一節內容,目前我們還沒有使用Migration指令,則需要手動將_Migration表刪除。

原理:

    從另外的表中獲取當前表每一行的額外的信息這種情況在舊系統中很常見。特別是當數據庫擴展時,沒有人喜歡在一些核心表中添加額外的列。這時候就可以通過另外的表來嫁接額外的信息。

    通過整合2個或多個表為單個實體類,更通俗的講,將單個實體類拆分成2個或多個表,這個過程通常稱為垂直拆分(vertical splitting)。

    垂直拆分的弊端是,每次我們需要獲取實體類的實例時,都需要使用join連接用于從其他表中獲取信息。

        using (var context = new EF6RecipesContext())
            {
                var product = new Product
                {
                    SKU = 147,
                    Description = "Expandable Hydration Pack",
                    Price = 19.97M,
                    ImageURL = "/pack147.jpg"
                };
                context.Products.Add(product);

                product = new Product
                {
                    SKU = 178,
                    Description = "Rugged Ranger Duffel Bag",
                    Price = 39.97M,
                    ImageURL = "/pack178.jpg"
                };
                context.Products.Add(product);

                product = new Product
                {
                    SKU = 186,
                    Description = "Range Field Pack",
                    Price = 98.97M,
                    ImageURL = "/nop_w_picpath.jpg"
                };
                context.Products.Add(product);

                product = new Product
                {
                    SKU = 202,
                    Description = "Small Deployment Back Pack",
                    Price = 29.97M,
                    ImageURL = "/pack202.jpg"
                };
                context.Products.Add(product);

                context.SaveChanges();
            }

            using (var context = new EF6RecipesContext())
            {
                foreach (var p in context.Products)
                {
                    Console.WriteLine("{0} {1} {2} {3}", p.SKU, p.Description,
                        p.Price.ToString("C"), p.ImageURL);
                }
            }

執行結果如下:

EF6 秘籍 2th:實體數據建模基礎 (九)切分一個實體到多張表

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

龙江县| 闽清县| 福泉市| 大同市| 武乡县| 华坪县| 凤阳县| 武山县| 囊谦县| 大安市| 达日县| 淳安县| 博爱县| 美姑县| 刚察县| 宕昌县| 循化| 济阳县| 慈利县| 尼木县| 射洪县| 宁陕县| 湟源县| 徐闻县| 嘉祥县| 抚顺县| 津南区| 渝北区| 周宁县| 顺平县| 武功县| 资溪县| 曲阜市| 五莲县| 娱乐| 南郑县| 海阳市| 瑞丽市| 濮阳县| 荥经县| 突泉县|