對(duì)linq多表查詢的淺析
linq多表查詢的實(shí)用性如何呢,本文就要來揭曉了,請(qǐng)大家仔細(xì)閱讀。
1:1關(guān)系的多表操作
表結(jié)構(gòu)如上
首先是測(cè)試取全記錄的情況(也就是取所有字段)
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多表查詢?cè)u(píng)分(1)
如果只是要取部分字段的話,我們必須在Select的時(shí)候指定要取的字段,這樣的話,在返回實(shí)例的易用性上,三種方式將是一樣的效果。
linq多表查詢?cè)u(píng)分(2)
至于具體怎么用就看各位喜好了…………..當(dāng)然,別忘了我們還有宇宙超級(jí)無敵的“視圖”可以使用...........
以上就是對(duì)linq多表查詢的簡單介紹。
【編輯推薦】