国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

多對多關系<EntityFramework6.0>

2019-11-14 16:26:59
字體:
來源:轉載
供稿:網友

無負載建立多對多關聯的模型

原文中是Modeling a Many-to-Many Relationship with No Payload,雖然這么翻譯也有點不準確,但是可以說明其目的,如下圖所示,數據庫中是這樣的關系,

我們按照Database Frist的開發模式,由向導創建模型,會得到幾個實體對象呢?

由此看出,這種多對多的關系賓補需要其它實體承載和轉換,那么Modeling a Many-to-Many Relationship with No Payload也就這個意思咯。

再看看它是怎么工作的:

       using (var context = new EF6RecipesContext__1())            {                // add an artist with two albums                var artist = new Artist { FirstName = "Alan", LastName = "Jackson" };                var album1 = new Album { AlbumName = "Drive" };                var album2 = new Album { AlbumName = "Live at Texas Stadium" };                artist.Albums.Add(album1);                artist.Albums.Add(album2);                context.Artists.Add(artist);                // add an album for two artists                var artist1 = new Artist { FirstName = "Tobby", LastName = "Keith" };                var artist2 = new Artist { FirstName = "Merle", LastName = "Haggard" };                var album = new Album { AlbumName = "Honkytonk University" };                artist1.Albums.Add(album);                artist2.Albums.Add(album);                context.Albums.Add(album);                context.SaveChanges();            }            using (var context = new EF6RecipesContext__1())            {                Console.WriteLine("Artists and their albums...");                var artists = context.Artists;                foreach (var artist in artists)                {                    Console.WriteLine("{0} {1}", artist.FirstName, artist.LastName);                    foreach (var album in artist.Albums)                    {                        Console.WriteLine("/t{0}", album.AlbumName);                    }                }                Console.WriteLine("/nAlbums and their artists...");                var albums = context.Albums;                foreach (var album in albums)                {                    Console.WriteLine("{0}", album.AlbumName);                    foreach (var artist in album.Artists)                    {                        Console.WriteLine("/t{0} {1}", artist.FirstName, artist.LastName);                    }                }            }

建立多對多關聯的模型并添加額外的信息

上面的LinkTable只包含了兩個外鍵信息,EntityFramework并不會為此生成一個EntityType,但是如果LinkTable中附加了一些信息,EntityFramework就會為此生成一個EntityType,形成兩個一對多的關聯如下:

那么根據向導生成的實體關系圖如下:

再看看它是如何讓工作的【書中這段代碼有點問題,現更正如下】

using (var context = new EF6_2RecipesContext())            {                var order = new Order                {                    OrderId = 1,                    OrderDate = new DateTime(2010, 1, 18)                };                var item = new Item                {                    SKU = 1729,                    Description = "Backpack",                    PRice = 29.97M                };                var oi = new OrderItem { Order = order, Item = item, Count = 1 };                context.OrderItems.Add(oi);                item = new Item                {                    SKU = 2929,                    Description = "Water Filter",                    Price = 13.97M                };                oi = new OrderItem { Order = order, Item = item, Count = 3 };                context.OrderItems.Add(oi);                item = new Item                {                    SKU = 1847,                    Description = "Camp Stove",                    Price = 43.99M                };                oi = new OrderItem { Order = order, Item = item, Count = 1 };                context.OrderItems.Add(oi);                context.SaveChanges();            }            using (var context = new EF6_2RecipesContext())            {                foreach (var order in context.Orders)                {                    Console.WriteLine("Order # {0}, ordered on {1}", order.OrderId,order.OrderDate);                    Console.WriteLine("SKU/tDescription/tQty/tPrice");                    Console.WriteLine("---/t-----------/t---/t-----");                    foreach (var oi in order.OrderItems)                    {                        Console.WriteLine("{0}/t{1}/t{2}/t{3}", oi.Item.SKU,                        oi.Item.Description, oi.Count,                        oi.Item.Price.ToString("C"));                    }                }            }

這也是書中推薦的建立多對多關系的方式,當然,項目的初期可能不需要添加額外的信息,而形成的第一種多對多的模式,那么書中也給出了最簡單也是最優的解決方案,就是在LinkTable中額外使用一個Int類型的標識列即可,這樣,到后期就可以體現出它的靈活性了。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 红原县| 鸡西市| 漳平市| 赤水市| 观塘区| 太白县| 鹤岗市| 惠来县| 黑山县| 巫山县| 石城县| 辰溪县| 青河县| 桃江县| 江川县| 大竹县| 商城县| 庄河市| 吉木萨尔县| 萍乡市| 浦城县| 阳朔县| 闻喜县| 林州市| 时尚| 满洲里市| 大关县| 奉节县| 四平市| 沭阳县| 日土县| 繁峙县| 黄龙县| 文化| 双流县| 秦皇岛市| 浮梁县| 玉林市| 宣武区| 杨浦区| 永泰县|