您好,登錄后才能下訂單哦!
這篇文章給大家介紹linq中怎么實現多表查詢,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
1:1關系的多表操作
表結構如上
首先是測試取全記錄的情況(也就是取所有字段)
linq多表查詢之直接寫表達式
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選項
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次數據,但是因為指定了LoadOption選項,所以也是一次性從數據庫取出來的。
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
但是要注意的一點是,如果用了.Select(p => new {p, p.UserData}) 這種代碼,你在使用實體的時候會稍微麻煩一點,要采用user.p.UserID這種形式,非常不爽。
可以這樣改進一下,寫成.Select(p => new {User = p, p.UserData})這種形式,這樣的話可以使用user.User.UserID來訪問。如果想直接用user.UserID來訪問的話,就必須在new的時候為每一個屬性賦名稱,如果數據表字段很多的話,那我只能恭喜你中獎啦。
如果要我評分的話,我會這樣評
linq多表查詢評分(1)
如果只是要取部分字段的話,我們必須在Select的時候指定要取的字段,這樣的話,在返回實例的易用性上,三種方式將是一樣的效果。
linq多表查詢評分(2)
關于linq中怎么實現多表查詢就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。