首页 > 互联资讯 > 技术交流  > 

.NET Core利用BsonDocumentProjectionDefinition和Lookup进行 join 关联查询(推荐)

目录
  • 前序
  • 1. 准备实体模型
  • 2 .前置连接Mongo代码
  • 3. 构建BsonDocumentProjectionDefinition
  • 4.利用 Lookup 进行关联

前序

前段时间由于项目需要用到MongoDB,但是MongoDB不建议Collection join 查询,网上很多例子查询都是基于linq 进行关联查询。但是在stackoverflow找到一个例子,程序员的朋友们请善于利用google搜索。主要介绍一个查询角色的所有用户的例子。MongoDB创建Collection 和准备数据,请自行处理。

1. 准备实体模型

/// 
    /// 用户实体(Collection)
    /// 
    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; }
    }
    /// 
    /// 角色实体(Collection)
    /// 
    public class Role
    {
        public Guid RoleId { get; set; }

        public string RoleName { get; set; }

        public DateTime CreateTime { get; set; }
    }
    /// 
    /// 构建用户Dto(不在Mongo创建Collection)
    /// 
    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 projectionDefinition = new BsonDocumentProjectionDefinition(
                        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 list = database.GetCollection(typeof(User).Name)
                .Aggregate()
                //过滤条件
                .Match(Builders.Filter.Eq("IsDelete", false))
                .Match(Builders.Filter.Eq("RoleId", roleId))
                //连接Role
                .Lookup(typeof(Role).Name, "RoleId", "RoleId", typeof(UserDto).Name)
                //查询需要显示的列
                .Project(projectionDefinition)
                .As().ToList();

到此这篇关于.NET Core利用BsonDocumentProjectionDefinition和Lookup进行 join 关联查询的文章就介绍到这了,更多相关.net core join 关联查询内容请搜索讯客以前的文章或继续浏览下面的相关文章希望大家以后多多支持讯客!

.NET Core利用BsonDocumentProjectionDefinition和Lookup进行 join 关联查询(推荐)由讯客互联技术交流栏目发布,感谢您对讯客互联的认可,以及对我们原创作品以及文章的青睐,非常欢迎各位朋友分享到个人网站或者朋友圈,但转载请说明文章出处“.NET Core利用BsonDocumentProjectionDefinition和Lookup进行 join 关联查询(推荐)