这次我要分享的是左连接查询,作为一个菜鸟我一开始完全不知道查询还分为普查、左、右、内查询,就更不要说会不会用了,但是经过了一番学习总算是明白了这些查询的区别与用法了。现在就上代码让大家审核审核本人的理解有没有问题,认为存在问题的望告知。
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表的全部条目数据都输出了,左连接的作用还是挺大的。
最后请看一下查询出来的结果数据是否与我说的一样。下面这张图就是左连接查询的效果图,这次的分享就到这了。