91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

甘南县| 体育| 淳化县| 北川| 共和县| 祁阳县| 左云县| 浠水县| 华安县| 聂荣县| 阿拉善盟| 威信县| 讷河市| 诸城市| 马鞍山市| 临沧市| 墨竹工卡县| 江阴市| 大竹县| 武邑县| 鄱阳县| 栖霞市| 鄂伦春自治旗| 资溪县| 洛川县| 亚东县| 伊金霍洛旗| 浠水县| 朝阳县| 大方县| 景德镇市| 杭州市| 汽车| 宁阳县| 三都| 桦川县| 清远市| 左权县| 平舆县| 甘谷县| 灵寿县|