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

MSSQL
sql 批量修改数据库表
mssql CASE,GROUP BY用法
利用SQL SERVER建立登录WINDOWS帐号
SQL Server 2008 正式版安装指南 包含序列号
SQL Server 2008图文安装教程
sql 语句 取数据库服务器上所有数据库的名字
sqlserver 数据类型转换小实验
SQL Server 存储过程解析
压缩技术给SQL Server备份文件瘦身
SQL Server 2005 还原数据库错误解决方法
Sql Server datetime问题
SQL语句 操作全集 学习mssql的朋友一定要看
格式导致的Excel导入sql出现异常的解决方法
SQL Server 数据库自动执行管理任务
sql Set IDENTITY_INSERT的用法
sql 修改表的所有者
过程需要参数 ''@statement'' 为 ''ntext/nchar/nvarchar'' 类型
mssql 建立索引
SQL Server 索引结构及其使用(一)--深入浅出理解索引结构
SQL Server 索引结构及其使用(二) 改善SQL语句

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


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