亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

.NET Core利用BsonDocumentProjectionDefinition和Lookup進行 join 關聯查詢(推薦)

瀏覽:204日期:2022-06-09 10:56:05
目錄
  • 前序
  • 1. 準備實體模型
  • 2 .前置連接Mongo代碼
  • 3. 構建BsonDocumentProjectionDefinition
  • 4.利用 Lookup 進行關聯

前序

前段時間由于項目需要用到MongoDB,但是MongoDB不建議Collection join 查詢,網上很多例子查詢都是基于linq 進行關聯查詢。但是在stackoverflow找到一個例子,程序員的朋友們請善于利用google搜索。主要介紹一個查詢角色的所有用戶的例子。MongoDB創建Collection 和準備數據,請自行處理。

1. 準備實體模型

/// <summary>
    /// 用戶實體(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>
    /// 角色實體(Collection)
    /// </summary>
    public class Role
    {
public Guid RoleId { get; set; }

public string RoleName { get; set; }

public DateTime CreateTime { get; set; }
    }
    /// <summary>
    /// 構建用戶Dto(不在Mongo創建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. 構建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 進行關聯

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();

到此這篇關于.NET Core利用BsonDocumentProjectionDefinition和Lookup進行 join 關聯查詢的文章就介紹到這了,更多相關.net core  join 關聯查詢內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: ASP.NET
主站蜘蛛池模板: 久久天天躁狠狠躁夜夜爽蜜月 | 国产精品一区二区手机看片 | 久久精品免费视频观看 | 日韩精品中文字幕在线 | 香蕉97碰碰视频在线看 | 绝对真实偷拍盗摄高清在线视频 | 久久免费看视频 | 欧美日韩国产综合视频一区二区三区 | 日本特黄特色aa大片免费 | 亚洲国产一区二区三区a毛片 | 我想看一级黄色大片 | 国产色在线 | 亚洲 国产色在线com | 色综合天天综合网国产成人网 | 婷婷香蕉 | 国产尤物在线播放 | 精品国产欧美另类一区 | 视频二区肥岳精品推荐 | 操碰在线视频 | 成人免费淫片在线费观看 | 亚洲综合免费 | 99人体做爰视频 | 久久成人国产精品二三区 | 九九国产在线视频 | 狠狠色丁香婷婷综合 | 午夜不卡av免费 | 制服丝袜中文字幕在线观看 | 国产精品久久久久久福利漫画 | 男女免费爽爽爽在线视频 | 亚洲欧美一区二区久久香蕉 | 亚洲 欧美 国产 制服 动漫 | 99视频精品免视3 | 黑人性视频做爰全过程视频 | 日本在观线免费观看 | 欧美日韩国产一区 | 日本精品视频在线观看 | 国产成人精品久久一区二区三区 | 人与牲动交xxxxbbbb高清 | 性美国xxxxx免费 | 国产一级久久免费特黄 | 日韩亚洲欧洲在线rrrr片 | 亚洲爱爱视频 |