左连接查询

这次我要分享的是左连接查询,作为一个菜鸟我一开始完全不知道查询还分为普查、左、右、内查询,就更不要说会不会用了,但是经过了一番学习总算是明白了这些查询的区别与用法了。现在就上代码让大家审核审核本人的理解有没有问题,认为存在问题的望告知。

public ActionResult deletionShift(){
            try{
              //1、左连接
                var LeftJoin = from e in myModels.B_Site
                               join d in myModels.B_ShiftSchedule on e.SiteID 
equals d.SiteID into JoinedEmpDept
                               from f in JoinedEmpDept.DefaultIfEmpty()
                               select new
                               {
                                   Network = e.Network,
                                   SiteID = e.SiteID,
                                   SiteName = e.SiteName,
                                   Shift = (f != null ? f.Shift : null),
                                   Shift=f. Shift,
                                 ShiftScheduleID = (f != null ? f.ShiftScheduleID : 0),
                               };
                return Json(LeftJoin, JsonRequestBehavior.AllowGet);
            }

            catch (Exception e)
            {
                Console.WriteLine(e);
                return Json("", JsonRequestBehavior.AllowGet);
            }
}

其实码中的d可以换成f,因为f表已经包含了d表,d表的字段也只能在f表用了。应该也可以理解为f表完全继承了d表的字段且不仅限于此。
查询的非主外键字段可以判断是不是为空,当然也可以不判断,像Shift = (f != null ? f.Shift : null),后面的null可以用你想要的东西填充,主键ShiftScheduleID = (f != null ? f.ShiftScheduleID : 0)就是必须要判断,不然会报错(填充内容均受限于字段的数据类型)。
填充的效果如下图所示,然后可以先滑到最后通过对比两张图的内容就不难理解我说的意思了。
在这里插入图片描述

接着大家看看数据库表的关系和数据内容,普通的查询只能查询出B_site表的前两条数据,而用左连接就可以把B_site表的全部数据与B_ShiftSchedule连接,连接不上的全部用null填充代替。这样就可以把B_site表的全部条目数据都输出了,左连接的作用还是挺大的。
在这里插入图片描述

最后请看一下查询出来的结果数据是否与我说的一样。下面这张图就是左连接查询的效果图,这次的分享就到这了。
在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值