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

MSSQL
使用SQL Server索引视图来提高性能
步骤指南:移植SQL 2000 DTS到SSIS
怎样使你的SQL运行得更加灵活和高效
优化SQL Server数据库服务器内存配置
SQL SERVER优化建议
请注意那些容易被忽略的SQL注入技巧
SQL Server 2005密码安全追踪与存储
sql2000下 分页存储过程
SQL Server数据库安全管理经验谈
测试SQL Server的业务规则链接方法
SQL Server的有效安装
SQL Server灾难恢复:重创历史性数据
SQL Server2005发布元年 微软正身企业级应用
MS SQL "1813"错误产生的原因及解决
收藏几段SQL Server语句和存储过程
SQL Server 2005中的备份和恢复增强
如何用SQL Server查询累计值
浅析如何掌握SQL Server的锁机制
步骤指南:测试MSSQL有没有特洛伊木马
手工卸载SQL Server 2000数据库

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-30   浏览: 143 ::
收藏到网摘: 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