您好,登錄后才能下訂單哦!
問題:
有2個或更多的表共享相同的主鍵,現在需要使用單個實體映射這些表。
解決方案:
數據庫圖表:
使用代碼優先的方式建模。
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); } }
執行結果如下:
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。