搜索

查看: 3116|回复: 11

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

[复制链接]
发表于 2023-5-4 11:25:05 | 显示全部楼层 |阅读模式
Editor 2023-5-4 11:25:05 3116 11 看全部
目录
  • 前序
  • 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[B] projectionDefinition = new BsonDocumentProjectionDefinition[B](
                            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[U] list = database.GetCollection[B](typeof(User).Name)
                    .Aggregate()
                    //过滤条件
                    .Match(Builders[B].Filter.Eq("IsDelete", false))
                    .Match(Builders[B].Filter.Eq("RoleId", roleId))
                    //连接Role
                    .Lookup(typeof(Role).Name, "RoleId", "RoleId", typeof(UserDto).Name)
                    //查询需要显示的列
                    .Project(projectionDefinition)
                    .As[U]().ToList();
    到此这篇关于.NET Core利用BsonDocumentProjectionDefinition和Lookup进行 join 关联查询的文章就介绍到这了,更多相关.net core  join 关联查询内容请搜索知鸟论坛以前的文章或继续浏览下面的相关文章希望大家以后多多支持知鸟论坛
  • 回复

    使用道具 举报

    发表于 2023-6-29 00:07:06 | 显示全部楼层
    十二音阶囤 2023-6-29 00:07:06 看全部
    既然你诚信诚意的推荐了,那我就勉为其难的看看吧!知鸟论坛不走平凡路。
    回复

    使用道具 举报

    发表于 2023-6-29 05:19:25 | 显示全部楼层
    啤酒瓶空了缓 2023-6-29 05:19:25 看全部
    其实我一直觉得楼主的品味不错!呵呵!知鸟论坛太棒了!
    回复

    使用道具 举报

    发表于 2023-6-29 18:03:18 | 显示全部楼层
    音乐之家1 2023-6-29 18:03:18 看全部
    既然你诚信诚意的推荐了,那我就勉为其难的看看吧!知鸟论坛不走平凡路。
    回复

    使用道具 举报

    发表于 2023-6-29 19:52:47 | 显示全部楼层
    普通人物怨 2023-6-29 19:52:47 看全部
    其实我一直觉得楼主的品味不错!呵呵!知鸟论坛太棒了!
    回复

    使用道具 举报

    发表于 2023-6-30 09:32:56 | 显示全部楼层
    冀苍鸾 2023-6-30 09:32:56 看全部
    楼主,我太崇拜你了!我想我是一天也不能离开知鸟论坛
    回复

    使用道具 举报

    发表于 2023-6-30 12:04:24 | 显示全部楼层
    xinting_6ym 2023-6-30 12:04:24 看全部
    我看不错噢 谢谢楼主!知鸟论坛越来越好!
    回复

    使用道具 举报

    发表于 2023-6-30 19:13:20 | 显示全部楼层
    小妖花满楼满fx 2023-6-30 19:13:20 看全部
    我看不错噢 谢谢楼主!知鸟论坛越来越好!
    回复

    使用道具 举报

    发表于 2023-7-4 01:30:04 | 显示全部楼层
    井底燕雀傥 2023-7-4 01:30:04 看全部
    楼主,我太崇拜你了!我想我是一天也不能离开知鸟论坛
    回复

    使用道具 举报

    发表于 2023-7-4 23:54:22 | 显示全部楼层
    123456823 2023-7-4 23:54:22 看全部
    楼主,我太崇拜你了!我想我是一天也不能离开知鸟论坛
    回复

    使用道具 举报

    • 您可能感兴趣
    点击右侧快捷回复 【请勿灌水】
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则 返回列表

    RSS订阅| SiteMap| 小黑屋| 知鸟论坛
    联系邮箱E-mail:zniao@foxmail.com
    快速回复 返回顶部 返回列表