Ejemplo n.º 1
0
        public async Task <(List <SysRoleMenu> list, long count)> QueryUserRole(Expression <Func <SysRoleMenu, bool> > where, Expression <Func <SysRoleMenu, bool> > orderby = null, PageInfo pageInfo = null)
        {
            //设置查询条件
            var select = DbType.DB().Select <SysRoleMenu>();

            var list = select.LeftJoin <SysMenu>((a, b) => a.MenuId == b.Id)
                       .LeftJoin <SysRole>((a, c) => a.RoleId == c.Id)
                       .Where(where);

            BaseEntity baseEntity = new BaseEntity();

            //设置排序
            if (orderby != null)
            {
                list = list.OrderBy(nameof(baseEntity.CreateDt) + " desc ");
            }

            var count = list.Count();

            //设置分页操作
            if (pageInfo != null && pageInfo.IsPaging)
            {
                list.Skip((pageInfo.PageIndex - 1) * pageInfo.PageSize).Limit(pageInfo.PageSize);
            }

            var resultList = await list.ToListAsync();

            //执行查询
            return(resultList, count);
        }
Ejemplo n.º 2
0
        /// <summary>
        /// 获取用户菜单权限
        /// </summary>
        /// <param name="where"></param>
        /// <param name="orderby"></param>
        /// <param name="pageInfo"></param>
        /// <returns></returns>
        public async Task <(List <SysRoleMenu> list, long count)> QueryUserMenu(long userid)
        {
            //设置查询条件
            var select = DbType.DB()
                         .Select <SysRoleMenu>();
            var list = select.LeftJoin <SysUserRole>((a, b) => a.RoleId == b.RoleId)
                       .LeftJoin <SysMenu>((a, c) => a.MenuId == c.Id)
                       .Where <SysUserRole>((rm, ur) => ur.UserId == userid);
            var count      = list.Count();
            var resultList = await list.ToListAsync();

            //执行查询
            return(resultList, count);
        }