首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > .NET > .NET >

主表连子表连两次取两个值 一条linq搞定 ?解决方法

2012-12-30 
主表连子表连两次取两个值 一条linq搞定 ? var query (from a in adviceNoteEarnestMoneyTableEntities.

主表连子表连两次取两个值 一条linq搞定 ?
 var query = (from a in adviceNoteEarnestMoneyTableEntities.View_AdviceNoteRightTable
                     join b in adviceNoteEarnestMoneyTableEntities.AdviceNoteLinkTable.Where(x => x.PayType == 42) on a.AdviceID equals b.AdviceID
                     join c in adviceNoteEarnestMoneyTableEntities.ExitRec on b.PayReturnID equals c.ID
                     join d in adviceNoteEarnestMoneyTableEntities.ContractSubReturnPayment.Where(y => y.PayType == 4) on c.ID equals d.RPID into t
                     from d in t.DefaultIfEmpty() into g
                     select new
                     {
                         AdviceID = g.Key.AdviceID,
                         AdviceState = g.Key.AdviceState,
                         AdviceType = g.Key.AdviceType,
                         ID = g.Key.ID,
                         OutDate = g.Key.OutDate,
                         ExitRecCount = g.ExitRecCount,
                         PayMoney = g.PayMoney
                     }).OrderByDescending(s => s.AdviceID);
我想让下面这个表在连一次并且这回paytype等于7了
adviceNoteEarnestMoneyTableEntities.ContractSubReturnPayment.Where(y => y.PayType == 7) 
完事要查出分别查出paytype是等于47时的paymonery,paymonery可以起别名,要左连接
[解决办法]
这段代码之后,继续用var query2一个查询,其中用let关键字使用你的query作为自查询。
反正Linq是延迟加载的。
[解决办法]


var query = (from a in adviceNoteEarnestMoneyTableEntities.View_AdviceNoteRightTable
  join b in adviceNoteEarnestMoneyTableEntities.AdviceNoteLinkTable.Where(x => x.PayType == 42) on a.AdviceID equals b.AdviceID
  join c in adviceNoteEarnestMoneyTableEntities.ExitRec on b.PayReturnID equals c.ID
  join d in adviceNoteEarnestMoneyTableEntities.ContractSubReturnPayment.Where(y => y.PayType == 4) on c.ID equals d.RPID into t


  from d in t.DefaultIfEmpty() 
  join e in adviceNoteEarnestMoneyTableEntities.TTTT on into e.id equals d.id into f
  from e in f.DefaultIfEmpty() 
  select new
  {
  AdviceID = a.AdviceID,
  AdviceState = a.AdviceState,
  AdviceType = a.AdviceType,
  OutDate = c.OutDate,
  ExitRecCount = c.ExitRecCount,
  PayMoney = d.PayMoney,
  tttt=e.tttt
  }).OrderByDescending(s => s.AdviceID);

热点排行