SQL Server 2005 中的树形数据处理示例-2

原创 2005年07月27日 17:00:00

-- =====================================================
-- 直接查询的应用实例
-- =====================================================

-- 1. 每个叶子结点的 FullName

WITH stb([id],[FullName],[pid],[flag])
AS(
    SELECT [id],CAST(RTRIM([name]) as nvarchar(4000)),[pid],1
    FROM [tb] A
    WHERE NOT EXISTS(
        SELECT 1 FROM [tb]
        WHERE [pid]=A.[id])
    UNION ALL
    SELECT A.[id],RTRIM(B.[name])+'/'+A.[FullName],B.[pid],A.flag+1
    FROM stb A,[tb] B
    WHERE A.[pid]=B.[id])
SELECT [id],[FullName] FROM stb A
WHERE NOT EXISTS(
    SELECT * FROM stb
    WHERE [id]=A.[id]
        AND flag>A.flag)
ORDER BY [id]
GO

-- 2. 每个结点的 FullName

WITH stb([id],[FullName],[pid],[flag])
AS(
    SELECT [id],CAST(RTRIM([name]) as nvarchar(4000)),[pid],1
    FROM [tb]
    UNION ALL
    SELECT A.[id],RTRIM(B.[name])+'/'+A.[FullName],B.[pid],A.flag+1
    FROM stb A,[tb] B
    WHERE A.[pid]=B.[id])
SELECT [id],[FullName] FROM stb A
WHERE NOT EXISTS(
    SELECT * FROM stb
    WHERE [id]=A.[id]
        AND flag>A.flag)
ORDER BY [id]
GO

-- 3. 树形显示数据

WITH stb([id],[level],[sid])
AS(
    SELECT [id],1,CAST(RIGHT(10000+[id],4) as varchar(8000))
    FROM [tb]
    WHERE [pid]=0
    UNION ALL
    SELECT A.[id],B.[level]+1,B.sid+RIGHT(10000+A.[id],4)
    FROM [tb] A,stb B
    WHERE A.[pid]=B.[id])
SELECT N'|'+REPLICATE('-',B.[level]*4)+A.name
FROM [tb] A,stb B 
WHERE a.[id]=b.[id]
ORDER BY b.sid    
GO

-- 4. 检查不规范的数据

WITH chktb([id],[pid],[level],[Path],[Flag])
AS(
    SELECT [id],[pid],1,
        CAST([id] as varchar(8000)),
        CASE WHEN [id]=[pid] THEN 1 ELSE 0 END
    FROM [tb]
    UNION ALL
    SELECT A.[id],B.[pid],B.[level]+1,
        CAST(B.[Path]+' > '+RTRIM(A.[id]) as varchar(8000)),
        CASE WHEN A.[id]=B.[pid] THEN 1 ELSE 0 END
    FROM [tb] A,chktb B
    WHERE A.[pid]=B.[id]
        AND B.[Flag]=0)
SELECT * FROM chktb 
WHERE [Flag]=1
ORDER BY [Path]    
GO

-- 5. 查询结点的所有子结点数

WITH sumtb([id],[level])
AS(
    SELECT [pid],1
    FROM [tb] A
    WHERE [pid]<>0
    UNION ALL
    SELECT A.[pid],B.[level]+1
    FROM [tb] A,sumtb B
    WHERE A.[id]=B.[id]
        AND A.[pid]<>0)
SELECT A.[id],ChildCounts=COUNT(b.[id])
FROM [tb] A
    LEFT JOIN sumtb B
        ON A.[id]=B.[id]
GROUP BY A.[id]
GO

-- 6. 查询结点的所有父结点数

WITH sumtb([id],[level],[ParentCounts])
AS(
    SELECT [id],1,0
    FROM [tb] A
    WHERE [pid]=0
    UNION ALL
    SELECT A.[id],B.[level]+1,B.[ParentCounts]+1
    FROM [tb] A,sumtb B
    WHERE A.[pid]=B.[id])
SELECT * FROM sumtb
order by [ID]
GO

SQL Server 2005 中的树形数据处理示例

-- 创建测试数据 if exists (select * from dbo.sysobjects where id = object_id(N'[tb]') and OBJECTPROPERTY(i...

SQL Server 2005 中的树形数据处理

-- 创建测试数据 if exists (select * from dbo.sysobjects where id = object_id(N'[tb]') and OBJECTPRO...

SQL Server 2005对海量数据处理

分类: SQL Server 2008-11-27 13:49 300人阅读 评论(0)收藏举报 数据库基础 SQL Server 2005对海量数据处理 SQL Server 2...

用Excel+VBA+SQL Server进行数据处理

sub test() '定义过程名称 Dim i As Integer, j As Integer, sht As Worksheet 'i,j为整数变量;sht 为excel工作表对象变量,指向某...
  • dawran
  • dawran
  • 2011年09月14日 16:27
  • 715

微软SQL Server引入Hadoop大数据处理能力

 [导读]运行SQL Server的微软客户将通过Hadoop的引入获得真正的大数据处理能力。微软已经发布了早期代码,让客户可以将这个Java架构接入到SQL Server 2008 R2、SQ...

SQL Server 2005对海量数据处理 .

超大型数据库的大小常常达到数百GB,有时甚至要用TB来计算。而单表的数据量往往会达到上亿的记录,并且记录数会随着时间而增长。这不但影响着数据库的运行效率,也增大数据库的维护难度。除了表的数据量外,对表...
  • guozh
  • guozh
  • 2011年07月21日 18:16
  • 455

SQL Server 2005利用分区对海量数据的处理

超大型数据库的大小常常达到数百GB,有时甚至要用TB来计算。而单表的数据量往往会达到上亿的记录,并且记录数会随着时间而增长。这不但影响着数据库的运行效率,也增大数据库的维护难度。除了表的数据量外,对表...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:SQL Server 2005 中的树形数据处理示例-2
举报原因:
原因补充:

(最多只允许输入30个字)