溫馨提示×

溫馨提示×

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

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

linq中怎么實(shí)現(xiàn)多表查詢

發(fā)布時(shí)間:2021-07-20 11:19:17 來源:億速云 閱讀:379 作者:Leah 欄目:編程語言

這篇文章給大家介紹linq中怎么實(shí)現(xiàn)多表查詢,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

1:1關(guān)系的多表操作

linq中怎么實(shí)現(xiàn)多表查詢
表結(jié)構(gòu)如上

首先是測試取全記錄的情況(也就是取所有字段)

linq多表查詢之直接寫表達(dá)式

var user = context.Users.Where(p => p.UserID == 10300).Select(p => new {p, p.UserData});  SELECT [t0].[UserID], [t0].[Email], [t0].[NickName], [t2].[test], [t2].[UserID] AS [UserID2], [t2].[MyInfo], [t2].[MyFriends] FROM [dbo].[Users] AS [t0] LEFT OUTER JOIN (SELECT 1 AS [test], [t1].[UserID], [t1].[MyInfo], [t1].[MyFriends] FROM [dbo].[UserData] AS [t1]) AS [t2] ON [t2].[UserID] = [t0].[UserID]WHERE [t0].[UserID] = 10300

linq多表查詢之使用LoadOption選項(xiàng)

var option = new DataLoadOptions();  option.LoadWith(p => p.UserData);  context.LoadOptions = option;  var user = context.Users.Where(p => p.UserID == 10300).Single();  var userdata = user.UserData;

雖然看上去取了2次數(shù)據(jù),但是因?yàn)橹付薒oadOption選項(xiàng),所以也是一次性從數(shù)據(jù)庫取出來的。

SELECT [t0].[UserID], [t0].[Email], [t0].[NickName], [t2].[test], [t2].[UserID] AS [UserID2], [t2].[MyInfo], [t2].[MyFriends] FROM [dbo].[Users] AS [t0]  LEFT OUTER JOIN (SELECT 1 AS [test], [t1].[UserID], [t1].[MyInfo], [t1].[MyFriends] FROM [dbo].[UserData] AS [t1]) AS [t2] ON [t2].[UserID] = [t0].[UserID]  WHERE [t0].[UserID] = 10300

linq多表查詢之使用Join語句

var user = context.Users.Where(p => p.UserID == 10300).Join(context.UserDatas, p => p.UserID, o => o.UserID, (o, p) => new { o, p });  SELECT [t0].[UserID], [t0].[Email], [t0].[NickName], [t1].[UserID] AS [UserID2], [t1].[MyInfo], [t1].[MyFriends] FROM [dbo].[Users] AS [t0] INNER JOIN [dbo].[UserData] AS [t1] ON [t0].[UserID] = [t1].[UserID] WHERE [t0].[UserID] = 10300

但是要注意的一點(diǎn)是,如果用了.Select(p => new {p, p.UserData}) 這種代碼,你在使用實(shí)體的時(shí)候會(huì)稍微麻煩一點(diǎn),要采用user.p.UserID這種形式,非常不爽。

可以這樣改進(jìn)一下,寫成.Select(p => new {User = p, p.UserData})這種形式,這樣的話可以使用user.User.UserID來訪問。如果想直接用user.UserID來訪問的話,就必須在new的時(shí)候?yàn)槊恳粋€(gè)屬性賦名稱,如果數(shù)據(jù)表字段很多的話,那我只能恭喜你中獎(jiǎng)啦。

如果要我評(píng)分的話,我會(huì)這樣評(píng)

linq中怎么實(shí)現(xiàn)多表查詢
linq多表查詢評(píng)分(1)

如果只是要取部分字段的話,我們必須在Select的時(shí)候指定要取的字段,這樣的話,在返回實(shí)例的易用性上,三種方式將是一樣的效果。

linq中怎么實(shí)現(xiàn)多表查詢
linq多表查詢評(píng)分(2)

關(guān)于linq中怎么實(shí)現(xiàn)多表查詢就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI