EF6秘籍2th:實體數(shù)據(jù)建?;A(chǔ)(九)切分一個實體到多張表

問題:

創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于網(wǎng)站制作、網(wǎng)站建設(shè)、玉屏網(wǎng)絡(luò)推廣、微信小程序開發(fā)、玉屏網(wǎng)絡(luò)營銷、玉屏企業(yè)策劃、玉屏品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎;創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供玉屏建站搭建服務(wù),24小時服務(wù)熱線:18980820575,官方網(wǎng)址:bm7419.com

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

解決方案:

    數(shù)據(jù)庫圖表:

EF6 秘籍 2th:實體數(shù)據(jù)建?;A(chǔ) (九)切分一個實體到多張表

    使用代碼優(yōu)先的方式建模。

    1、添加ADO.NET實體數(shù)據(jù)模型,命名模型為EF6CodeFirstRecipesContext,選擇空代碼優(yōu)先模型。

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

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

     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");
                });

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

原理:

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

    通過整合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);
                }
            }

執(zhí)行結(jié)果如下:

EF6 秘籍 2th:實體數(shù)據(jù)建?;A(chǔ) (九)切分一個實體到多張表

當(dāng)前題目:EF6秘籍2th:實體數(shù)據(jù)建?;A(chǔ)(九)切分一個實體到多張表
標(biāo)題網(wǎng)址:http://bm7419.com/article6/jccgig.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、網(wǎng)頁設(shè)計公司、微信小程序、軟件開發(fā)、域名注冊、品牌網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運營