当前位置: 首页 > 图文教程 > 数据库 > MSSQL > SQL Server存储层级数据实现无限级分类

MSSQL
SQL Server中容易混淆的数据类型
影响SQL Server性能的主要原因
浅谈SQL Server查询优化器中的JOIN算法
怎样缩小SQL Server数据库日志文件
SQL Server 2005最值得你升级的10个理由
SQL Server 商务智能特性对比
SQL Server 2005 SP1的新特性
怎样使用SQL Server来过滤数据
在SQL Server中处理空值时涉及的三个问题
怎样才能保护好 SQL Server 数据库
SQL SERVER数据库口令的脆弱性
SQL Server中的动态和静态内存分配
SQL存储过程学习:特殊的存储过程-触发器
几条常见的数据库分页 SQL 语句
SQL Server 2008服务器合并功能介绍
SQL Server数据库开发的二十一条军规
SQL Server 2008 的管理能力
快速删除重复记录,SQL Server如何实现?
将MySQL数据导入到Sql Server中
SQL Server和MySQL的安全性分析

MSSQL 中的 SQL Server存储层级数据实现无限级分类


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-30   浏览: 71 ::
收藏到网摘: n/a

我们先建立一个数据表,结构如下图(LID 为左值,RID 为右值,Tree 为节点深度,Name 和 ID 就不多说了,节点的索引和名称)

我们可以使用下面的存储过程来获得一个节点和其子节点:

  1. CREATE PROCEDURE CLSP_ZoneSelect  
  2. (  
  3.     @Root INT,  
  4.     @Tree INT 
  5. )  
  6. AS 
  7.     SELECT Z.ID,Z.Tree,Z.Name  
  8.     FROM CL_ZoneData AS Z,CL_ZoneData AS P  
  9.     WHERE   P.ID = @Root  
  10.          AND Z.LID >= P.LID AND Z.RID <= P.RID  
  11.             AND (@Tree = 0 OR Z.Tree <= P.Tree + @Tree)  
  12.     ORDER BY Z.LID ASC 
  13. GO 

我们可以用下面这个存储过程来在一个节点下插入新的子节点:

  1. CREATE PROCEDURE CLSP_ZoneInsert  
  2. (  
  3.     @Root INT,  
  4.     @Name NVARCHAR(50)  
  5. )  
  6. AS 
  7.     DECLARE @RID AS INT,@NID AS INT,@Tree AS INT 
  8.  
  9.     SET @RID = 1  
  10.     SET @NID = 0  
  11.     SET @Tree = 1  
  12.  
  13.     IF @Root = 0  
  14.     BEGIN 
  15.         SELECT TOP 1 @RID = RID + 1  
  16.         FROM CL_CateData ORDER BY RID DESC 
  17.     END 
  18.     ELSE 
  19.     BEGIN 
  20.         SELECT @RID = RID, @Tree = Tree + 1  
  21.         FROM CL_ZoneData WHERE ID = @Root  
  22.     END 
  23.  
  24.     IF @Root = 0 OR @RID > 1  
  25.     BEGIN 
  26.         UPDATE CL_ZoneData SET RID = RID + 2 WHERE RID >= @RID  
  27.         UPDATE CL_ZoneData SET LID = LID + 2 WHERE LID > @RID  
  28.  
  29.         INSERT INTO CL_ZoneData(LID,RID,Tree,Name)  
  30.         VALUES (@RID,@RID + 1,@Tree,@Name)  
  31.  
  32.         SET @NID = SCOPE_IDENTITY()  
  33.     END 
  34.     SELECT @NID  
  35. GO 

删除一个节点可以用下面的存储过程:

  1. CREATE PROCEDURE CLSP_ZoneDelete  
  2. (  
  3.     @ID INT 
  4. )   
  5. AS 
  6.     DECLARE @LID AS INT, @RID AS INT, @WID AS INT, @DID AS INT 
  7.     SET @DID = 0  
  8.     SELECT @DID = ID, @LID = LID, @RID = RID, @WID = RID - LID + 1 FROM CL_ZoneData WHERE ID = @ID  
  9.     IF @DID != 0  
  10.     BEGIN 
  11.         DELETE FROM CL_ZoneData WHERE LID BETWEEN @LID AND @RID  
  12.         UPDATE CL_ZoneData SET RID = RID - @WID WHERE RID > @RID  
  13.         UPDATE CL_ZoneData SET LID = LID - @WID WHERE LID > @RID  
  14.     END 
  15.     SELECT @DID  
  16. GO