linq To SQl之多表联合查询

本文介绍了两种使用LINQ进行多表联合查询的方法。第一种是在数据控件绑定时,通过LINQ Server Mode DataSource进行查询,将角色表与父角色表连接,并过滤出未删除的角色。第二种是在普通绑定方法中设置联合主键,通过三个表(用户组别、用户、用户组)的连接获取详细用户信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

方法一:数据控件绑定   

protected void LinqServerModeDataSource1_Selecting(object sender, DevExpress.Data.Linq.LinqServerModeDataSourceSelectEventArgs e)
        {

            ASPxGridView1.KeyFieldName = "RoleID";
            e.KeyExpression = "RoleID";
            e.QueryableSource = from r1 in eDataContext.Role
                                join r2 in eDataContext.Role on r1.ParentRoleID equals r2.RoleID
                                where r1.IsDeleted == false
                                select new { ParentRoleID = r1.ParentRoleID, RoleID = r1.RoleID, RoleName = r1.RoleName, RoleDesc = r1.RoleDesc, ParentRoleName = r2.RoleName };

        }

 

方法二:普通绑定方法中设置联合主键(用户组别编号和用户编号组合而成)

        Casagroup.Entities.EntitiesDataContext eDataContext = new Casagroup.Entities.EntitiesDataContext();
        Common _common = new Common();
        private void BindUserInfo()
        {
            UserGroup c = new UserGroup();

 
            //联合查询用户信息
            var result = from ugu in eDataContext.UserGroupUser
                         join us in eDataContext.User on ugu.UserID equals us.UserID
                         join ug in eDataContext.UserGroup on ugu.UserGroupID equals ug.UserGroupID
                         select new { ID = ugu.ID + "_" + us.UserID, UserPWD = us.UserPWD, UserGroupID = ugu.UserGroupID, UserID = us.UserID, UserName = us.UserName, UserGroupName = ug.UserGroupName, IsEnabled = us.IsEnabled };

            this.gvUser.DataSource = result;
            this.gvUser.DataBind();

        }

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值