linq to sql多表基础描述

开发 后端
linq的编写方式看起来很拉风,但他并不是很么的完美,有利肯定有弊.推出linq这么长时间了.也没见市场上很热门.用的人还是很少.这次在开发的过程中.最让我抓狂的就是linq to sql多表关联与动态条件查询.

本文主要阐述linq to sql多表关联与动态条件查询,虽然好多人对linq很不熟悉,但是本文作者简言较简单,还是很容易理解的。

在去年的有接触过linq,也小试了一刀.但仅仅是简单的from并没有深入去揣摩.这次正好用MVC开发这套系统.所以使用linq 是必须的.

之前我也有说过linq的编写方式看起来很拉风,但他并不是很么的***,有利肯定有弊.要不microsoft推出linq这么长时间了.也没见市场上很热门.至今在我看来.用的人还是很少.这次在开发的过程中.最让我抓狂的就是linq to sql多表关联与动态条件查询.

虽然网上有很多资料是linq to sql多表关系当然也有动态条件查询的.但是并没有找到我想要的答案.与是只能靠自己摸索了.下面就是我要实现的结果,linq to sql多表关联.INNER JOIN + LEFT JOIN

  1. var q =  
  2.   (from ar in db.Articles  
  3.    join c in db.Categories on ar.ParentId  
  4.    equals c.Id  
  5.    join sc in db.Categories on ar.SubId equals sc.Id into scate  
  6.    from sc in scate.DefaultIfEmpty()  
  7.    where ar.IsPrivate == false  
  8.    orderby ar.CreateTime descending   
  9.    __select new  
  10.     {  
  11.        ararticle = ar,  
  12.        pcate = c,  
  13.        scscate = sc  
  14.     }).Take(3); 

linq to sql多表动态条件查询:

  1. Expression> lambda = ar => (1==1);  
  2.             if (id != null)  
  3.                 lambda = (ar => ar.Id == id);   
  4.             var article = db.Articles.OrderByDescending
  5. (a => a.CreateTime).Where(lambda);  
  6.      return View(article);  

linq to sql多表,如果你要根据条件不同显示相应的数据的话,只要在q对像后追加Where()就OK:

  1. int Record__count = q.Count(); //得到记录数     
  2.            int page = PagerHelper.GetCurrentPage();     
  3.            int SkipIndex = (page-1)__ * 5;  
  4.            var q = (from ar in db.Articles  
  5.     join c in db.Categories on ar.ParentId  
  6.         equals c.Id  
  7.     join sc in db.Categories on ar.SubId equals sc.Id into scate  
  8.     from sc in scate.DefaultIfEmpty()  
  9.     where ar.IsPrivate == false  
  10.     orderby ar.CreateTime descending  
  11.     __select new  
  12.     {  
  13.         ararticle = ar,  
  14.         pcate = c,  
  15.         scscate = sc  
  16.     });.Skip(SkipIndex).Take(5); 

以上就是对linq to sql多表的详细阐述。

【编辑推荐】

  1. 深入浅出 LINQ表达式
  2. LINQ基础学习之LINQ to XML
  3. 学习心得LINQ to XML
  4. 浅析LINQ开发技术之LINQ to XML
  5. 详细阐述linq动态排序
责任编辑:阡陌 来源: 百度空间
相关推荐

2009-09-10 10:37:15

LINQ to SQL

2009-09-16 09:38:27

LINQ To SQL

2009-09-17 17:34:23

linq to sql

2009-09-17 18:05:15

linq to sql

2009-09-15 11:14:33

LINQ to SQL

2009-09-15 13:14:01

LINQ to SQL

2009-09-15 10:02:44

Linq to SQL

2009-09-18 16:41:46

Linq to sql

2009-09-17 11:08:55

LINQ查询表达式

2009-09-09 15:37:27

Linq DataLo

2010-08-24 09:47:05

LINQ to SQL

2009-09-14 15:43:12

Linq Settin

2009-09-09 15:28:43

Linq to obj

2009-09-18 16:00:07

LINQ架构

2009-09-14 10:57:46

LINQ入门

2009-09-10 15:26:03

Linq City集合

2009-09-15 16:26:36

Linq orderb

2009-09-15 10:35:11

linq多表查询

2009-09-14 16:33:55

LINQ To XML

2009-09-11 10:20:36

Linq扩展方法
点赞
收藏

51CTO技术栈公众号