码迷,mamicode.com
首页 > 数据库 > 详细

LINQ TO SQL 实现无限递归查询

时间:2014-06-21 13:26:29      阅读:217      评论:0      收藏:0      [点我收藏+]

标签:style   class   blog   code   ext   color   

LINQ TO SQL 实现无限递归查询

现总结一下,希望能给以后再碰到此类问题的朋友一些帮助

 

--构造测试数据: 只作演示用
CREATE TABLE [dbo].[Tim_LinqTable](
[Id] int PRIMARY KEY IDENTITY(1,1) NOT NULL,
[Name] [varchar](50) NOT NULL,
[Parent] int NOT NULL,
)
GO
 
INSERT INTO [Tim_LinqTable]  
SELECT A,0 UNION ALL
SELECT A1,1 UNION ALL
SELECT A2,1 UNION ALL
SELECT B1,2 UNION ALL
SELECT B2,3 UNION ALL
SELECT C1,4 UNION ALL
SELECT C2,4 UNION ALL
SELECT D1,5 UNION ALL
SELECT D2,5 UNION ALL
SELECT D3,5 
GO
 
WITH temp
AS
(
SELECT * FROM [Tim_LinqTable]  WHERE Parent = 3
UNION ALL
SELECT m.* FROM [Tim_LinqTable]  AS m
INNER JOIN temp AS child ON m.Parent = child.Id
)
SELECT * FROM temp
GO
 
--查询 Parent=3 的所有子数据结果如下:
Id          Name                                               Parent
----------- -------------------------------------------------- -----------
5           B2                                                 3
8           D1                                                 5
9           D2                                                 5
10          D3                                                 5
 
(4 row(s) affected)

 

//好,下边来看看用C#怎么实现上边的SQL语句吧:
void Main()
{
     var query=GetClassID(3);
     Console.WriteLine("Id\tName\tParent");
     query.ToList().ForEach(q=>Console.WriteLine("{0}\t{1}\t{2}",q.Id,q.Name,q.Parent));
     /*
        Id       Name       Parent
        5        B2         3
        8        D1         5
        9        D2         5
       10        D3         5
     */
}
public IEnumerable<Tim_LinqTable> GetClassID(int p_id)
{
            var query = from c in this.Tim_LinqTables
                        where c.Parent  == p_id
                        select c;
         
           return  query.ToList().Concat(query.ToList().SelectMany(t => GetClassID(t.Id)));              
}

 

LINQ TO SQL 实现无限递归查询,布布扣,bubuko.com

LINQ TO SQL 实现无限递归查询

标签:style   class   blog   code   ext   color   

原文地址:http://www.cnblogs.com/yangzhx/p/3794690.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!