递归树 获取同级及子级

/// <summary>
        /// 创建人:tqy 创建时间:2017-8-24
        /// 修改人:   修改时间:
        /// 说明:获取部门信息,同级及子级
        /// </summary>
        /// <returns>部门信息</returns>
        public Result GetDepartmentSub(int depid)
        {
            var resulta = from c in db.DepartmentSet
                          join b in db.DepartmentSet on c.ParentId equals b.ParentId
                          where (c.Id == depid)
                            select new VGetDepartmentTree
                            {
                                Id = b.Id,
                                Name = b.Name,
                                ParentId = b.ParentId,
                                TreeType = db.DepartmentSet
                                                                            .Where(ds => ds.ParentId == b.Id).Count() > 0 ? "r" : "c"
                            };
            //var resultb = from c in db.DepartmentSet
            //              join b in db.DepartmentSet on c.Id equals b.ParentId
            //              where (c.Id == depid)
            //              select new VGetDepartmentTree
            //              {
            //                  Id = b.Id,
            //                  Name = b.Name,
            //                  ParentId = b.ParentId,
            //                  TreeType = db.DepartmentSet
            //                                                              .Where(ds => ds.ParentId == b.Id).Count() > 0 ? "r" : "c"
            //              };
            var resultb = GetDparentsID(depid);
            var result = resulta.ToList().Concat(resultb);

            var data = new { data = result,
                rootdep = resulta.Take(1)
            };
            return new Result { IsSuccess = true, Data = data };
        }

        /// <summary>
        /// 递归查询部门,
        /// </summary>
        /// <param name="p_id">父级部门ID</param>
        /// <returns></returns>
        public IEnumerable<VGetDepartmentTree> GetDparentsID(int p_id)
        {
            var resultb = from c in db.DepartmentSet
                          join b in db.DepartmentSet on c.Id equals b.ParentId
                          where (c.Id == p_id)
                          select new VGetDepartmentTree
                          {
                              Id = b.Id,
                              Name = b.Name,
                              ParentId = b.ParentId,
                              TreeType = db.DepartmentSet
                                                                    .Where(ds => ds.ParentId == b.Id).Count() > 0 ? "r" : "c"
                          };
            return resultb.ToList().Concat(resultb.ToList().SelectMany(t => GetDparentsID(t.Id)));
        }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值