ef 多表联接查询

关于linq的多表联查效果的实现:

后台多表查询  内连接:

SELECT
[Extent2].[partID] AS [partID],
[Extent1].[userName] AS [userName],
[Extent3].[partName] AS [partName]
FROM [dbo].[User] AS [Extent1]
INNER JOIN [dbo].[User_partB] AS [Extent2] ON [Extent1].[userGUID] = [Extent2].[userGUID]
INNER JOIN [dbo].[partB] AS [Extent3] ON [Extent2].[partID] = [Extent3].[partID]

var userListTest = (from u in db.Users
                                join p in db.User_partB on u.userGUID
              equals p.userGUID
                                join d in db.partBs on p.partID equals d.partID
                                select new { name = u.userName, departName = d.partName });
            List<dynamic> oneList = new List<dynamic>();
            foreach (var one in userListTest.ToList())
            {
                dynamic dyObject = new ExpandoObject();
                dyObject.userName = one.name;
                dyObject.departName = one.departName;
                oneList.Add(dyObject);
            }
            ViewBag.dyObject = oneList;
            return View();

前台数据数据表示的方法:

 
<table>
    <tr><td>用户登录名</td><td>姓名</td><td>状态</td><td>角色</td><td>操作</td></tr>
    @{foreach (var one in ViewBag.dyObject)
    {
        <tr>
            @*<td>@one.userLoginName</td>*@
            <td>@one.userName</td>
            @*<td>@one.active==1?"启用":"禁用"</td>*@
            <td>@one.departName</td>
            <td></td>
        </tr>
    }
    }
</table>


linq  多表联查 外链接:

SELECT
1 AS [C1],
[Extent1].[userName] AS [userName],
[Extent3].[partName] AS [partName]
FROM [dbo].[User] AS [Extent1]
LEFT OUTER JOIN [dbo].[User_partB] AS [Extent2] ON [Extent1].[userGUID] = [Extent2].[userGUID]
LEFT OUTER JOIN [dbo].[partB] AS [Extent3] ON [Extent2].[partID] = [Extent3].[partID]


var userListTest = (from u in db.Users
                                join p in db.User_partB on u.userGUID
              equals p.userGUID into temp
                                from t in temp.DefaultIfEmpty()
                                join d in db.partBs on t.partID equals d.partID 
                                into tempone
                                from user in tempone.DefaultIfEmpty()
                                select new { name = u.userName, departName = user.partName });
            List<dynamic> oneList = new List<dynamic>();
            foreach (var one in userListTest.ToList())
            {
                dynamic dyObject = new ExpandoObject();
                dyObject.userName = one.name;
                dyObject.departName = one.departName;
                oneList.Add(dyObject);
            }
            ViewBag.dyObject = oneList;
            return View();


前台数据展示效果同上

上述过程中,遇到  延迟加载后的动态数据,TOList()之后,传递到前台后,在foreach循环时,无法通过对象.属性的形式,读取出来,报“OBJECT未定义该属性”,经过查找原因发现,该动态数据为internal类型,只能同一程序集内访问,找了若干方法,不太适用,当然,如果大家有好的建议,可以一起交流讨论,究于当前场景,我选择了ExpandoObject,来动态处理,linq的查询结果。



  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值