首页 > 数据库技术 > 详细

LINQ TO SQL 实现无限递归查询

时间:2014-06-21 13:25:49      阅读:425      评论:0      收藏:0      [点我收藏+]

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 实现无限递归查询

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

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!