如何在Sql Server 2000中用一条语句实现树的查询
2017-08-16 14:56
671 查看
以公司的网站栏目表为例,表结构(表名:Subject)如下:
在数据库中创建一个自定义函数:
CREATE FUNCTION dbo.GetSubtreeInfo
( @manager_id AS char(5)
)
RETURNS @treeinfo table
( [id] [int] NOT NULL ,
[name] [varchar] (100) NOT NULL,
[parentid] [int] NOT NULL,
[code] [varchar] (100) NULL,
[levels] [int] NOT NULL
) AS
BEGIN
DECLARE @level AS int
SELECT @level = 0
INSERT INTO @treeinfo
SELECT [id], [name], [parentid], [code], @level
FROM [subject]
WHERE [id] = @manager_id
WHILE @@ROWCOUNT > 0
BEGIN
SET @level = @level + 1
INSERT INTO @treeinfo
SELECT E.[id], E.[name], E.[parentid], E.[code], @level
FROM [subject] AS E JOIN @treeinfo AS T
ON E.[parentid] = T.[id] AND T.[levels] = @level - 1
END
RETURN
END
说明:其中的levels是树状结构的级数
使用方法:select SPACE(levels*3)+name ,* from GetSubtreeInfo(973) 其中973可以修改为你要开始查询的起始节点
字段名称 | 字段类型 | 字段长度 |
id | int | 4 |
NAME | varchar | 200 |
PARENTID | int | 4 |
CODE | varchar | 100 |
CREATE FUNCTION dbo.GetSubtreeInfo
( @manager_id AS char(5)
)
RETURNS @treeinfo table
( [id] [int] NOT NULL ,
[name] [varchar] (100) NOT NULL,
[parentid] [int] NOT NULL,
[code] [varchar] (100) NULL,
[levels] [int] NOT NULL
) AS
BEGIN
DECLARE @level AS int
SELECT @level = 0
INSERT INTO @treeinfo
SELECT [id], [name], [parentid], [code], @level
FROM [subject]
WHERE [id] = @manager_id
WHILE @@ROWCOUNT > 0
BEGIN
SET @level = @level + 1
INSERT INTO @treeinfo
SELECT E.[id], E.[name], E.[parentid], E.[code], @level
FROM [subject] AS E JOIN @treeinfo AS T
ON E.[parentid] = T.[id] AND T.[levels] = @level - 1
END
RETURN
END
说明:其中的levels是树状结构的级数
使用方法:select SPACE(levels*3)+name ,* from GetSubtreeInfo(973) 其中973可以修改为你要开始查询的起始节点
相关文章推荐
- 如何在Sql Server 2000中用一条语句实现树的查询
- 【MySQL】如何使用C#+MySQL实现一条MySQL语句进行多表查询
- Oracle, SQL Server, My SQL如何实现数据分页查询语句
- 【MySQL】如何使用C#+MySQL实现一条MySQL语句进行多表查询
- 在sql server中,如何使用一条语句实现将表1中的数据复制到表2中
- Oracle, SQL Server, My SQL如何实现数据分页查询语句
- 一条SQL语句搞定Sql Server 2000 分页
- Sql Server 2000 中 将 0,1 字段,换成 是,否 的查询语句
- 【转】在SQL Server中通过SQL语句实现分页查询
- 在SQL Server中通过SQL语句实现分页查询
- 在SQL Server中通过SQL语句实现分页查询
- Sql Server 2000,Sql Server 2005以及Oracle下如何实现数据分页
- 如何查询SQL Server 2000 SP4补丁已安装成功
- 【SQL精彩语句】SQL SERVER 2000中查询指定节点及其所有子节点的函数(表格形式显示)
- 一条SQL语句实现查询每个部门中年龄最大的员工信息
- SQL语句实现SQL Server 2000及ACCESS复制表或表结构及内容到新的表
- SQL 2000 如何优化查询语句,提高查询效率.
- SQL语句实现SQL Server 2000及Sql Server 2005日志收缩(批量)
- SQL Server 2000如何用SQL语句在在指定位置插入列
- 在SQL Server 2005 中是如何知道一条SQL 语句运行多长时间、CPU 运行率