.NET?Core利用BsonDocumentProjectionDefinition和Lookup進(jìn)行?join?關(guān)聯(lián)查詢(推薦)
前序
前段時(shí)間由于項(xiàng)目需要用到MongoDB,但是MongoDB不建議Collection join 查詢,網(wǎng)上很多例子查詢都是基于linq 進(jìn)行關(guān)聯(lián)查詢。但是在stackoverflow找到一個(gè)例子,程序員的朋友們請(qǐng)善于利用google搜索。主要介紹一個(gè)查詢角色的所有用戶的例子。MongoDB創(chuàng)建Collection 和準(zhǔn)備數(shù)據(jù),請(qǐng)自行處理。
1. 準(zhǔn)備實(shí)體模型
/// <summary> /// 用戶實(shí)體(Collection) /// </summary> public class User { public Guid UserId { get; set; } public string UserName { get; set; } public string Password { get; set; } public bool IsDelete { get; set; } public DateTime CreateTime { get; set; } public Guid RoleId { get; set; } } /// <summary> /// 角色實(shí)體(Collection) /// </summary> public class Role { public Guid RoleId { get; set; } public string RoleName { get; set; } public DateTime CreateTime { get; set; } } /// <summary> /// 構(gòu)建用戶Dto(不在Mongo創(chuàng)建Collection) /// </summary> public class UserDto { public Guid UserId { get; set; } public string UserName { get; set; } public DateTime CreateTime { get; set; } public Guid RoleId { get; set; } public string RoleName { get; set; } }
2 .前置連接Mongo代碼
var client = new MongoClient("xxx"); var database = client.GetDatabase("xxx");
3. 構(gòu)建BsonDocumentProjectionDefinition
BsonDocumentProjectionDefinition<BsonDocument> projectionDefinition = new BsonDocumentProjectionDefinition<BsonDocument>( new BsonDocument("UserId", "$UserId") .Add("UserName", "$UserName") .Add("CreateTime", "$CreateTime") .Add("RoleId", "$RoleId") .Add("RoleName", new BsonDocument("$arrayElemAt", new BsonArray().Add("$Role.RoleName").Add(0))) );
4.利用 Lookup 進(jìn)行關(guān)聯(lián)
Guid roleId = Guid.Empty; List<UserDto> list = database.GetCollection<BsonDocument>(typeof(User).Name) .Aggregate() //過濾條件 .Match(Builders<BsonDocument>.Filter.Eq("IsDelete", false)) .Match(Builders<BsonDocument>.Filter.Eq("RoleId", roleId)) //連接Role .Lookup(typeof(Role).Name, "RoleId", "RoleId", typeof(UserDto).Name) //查詢需要顯示的列 .Project(projectionDefinition) .As<UserDto>().ToList();
到此這篇關(guān)于.NET Core利用BsonDocumentProjectionDefinition和Lookup進(jìn)行 join 關(guān)聯(lián)查詢的文章就介紹到這了,更多相關(guān).net core join 關(guān)聯(lián)查詢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
asp.net(C#)實(shí)現(xiàn)功能強(qiáng)大的時(shí)間日期處理類完整實(shí)例
這篇文章主要介紹了asp.net(C#)實(shí)現(xiàn)功能強(qiáng)大的時(shí)間日期處理類,封裝了針對(duì)日期與時(shí)間的各種常用的判斷與計(jì)算功能,非常方便實(shí)用,需要的朋友可以參考下2016-06-06asp.net導(dǎo)出Excel顯示中文亂碼的解決方法
asp.net導(dǎo)出Excel顯示中文亂碼的解決方法,需要的朋友可以參考一下2013-03-03ASP.NET?Core構(gòu)建OData查詢Restful?API
這篇文章主要為大家介紹了ASP.NET?Core建構(gòu)OData實(shí)體模型實(shí)現(xiàn)Restful?API查詢,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-04-04Aspose.Cells 讀取受保護(hù)有密碼的Excel文件
這篇文章主要介紹了Aspose.Cells 讀取受保護(hù)有密碼的Excel文件,簡(jiǎn)單實(shí)用,需要的朋友可以參考下。2016-06-06