問題:
創(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ù)庫圖表:
使用代碼優(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é)果如下:
當(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)