简单查询树形结构数据库表

简介:   在与同事Rock讨论中,得到一个思路,不用嵌套调用直接用一个语句就可以生成树,实事上他已经做好了该程序,他用了临时表写了一个存储过程,我改写为一个表值函数,供大家参考:表结构及表值函数如下: 查询树表语句  1 /**/ /* ***** Object:  Table [dbo].

 

在与同事Rock讨论中,得到一个思路,不用嵌套调用直接用一个语句就可以生成树,实事上他已经做好了该程序,他用了临时表写了一个存储过程,我改写为一个表值函数,供大家参考:

表结构及表值函数如下:

查询树表语句
 1 /**/ /* ***** Object:  Table [dbo].[Tree]    Script Date: 2005-11-04 18:07:00 ***** */
 2 CREATE   TABLE   [ dbo ] . [ Tree ]  (
 3   [ ID ]   [ int ]   IDENTITY  ( 1 1 NOT   NULL  ,
 4   [ PID ]   [ int ]   NULL  ,
 5   [ Name ]   [ varchar ]  ( 10 ) COLLATE Chinese_PRC_CI_AS  NULL  
 6 ON   [ PRIMARY ]
 7 GO
 8
 9   CREATE    CLUSTERED    INDEX   [ IX_Tree ]   ON   [ dbo ] . [ Tree ] ( [ PID ] ON   [ PRIMARY ]
10 GO
11
12 ALTER   TABLE   [ dbo ] . [ Tree ]   WITH   NOCHECK   ADD  
13   CONSTRAINT   [ PK_Tree ]   PRIMARY   KEY    NONCLUSTERED  
14  (
15    [ ID ]
16  )   ON   [ PRIMARY ]  ,
17   CONSTRAINT   [ 子ID不能等于父ID ]   CHECK  ( [ ID ]   <>   [ PID ] )
18 GO
19
20 ALTER   TABLE   [ dbo ] . [ Tree ]   ADD  
21   CONSTRAINT   [ FK_Tree_Tree ]   FOREIGN   KEY  
22  (
23    [ PID ]
24  )  REFERENCES   [ dbo ] . [ Tree ]  (
25    [ ID ]
26  )
27 GO
28
29 /**/ /* ***** 对象:  用户定义的函数 dbo.fGetTreeTable    脚本日期: 2005-11-04 18:07:02 ***** */
30 CREATE   FUNCTION  dbo.fGetTreeTable
31  (
32   @ID   int =   null
33  )
34 RETURNS   @Tab   TABLE (ID  int , PID  int , Name  varchar ( 10 ), Lev  int )
35 AS
36   BEGIN
37    Declare   @lev   int
38    Set   @lev = 0
39   
40    While   @lev = 0   or   @@ROWCount > 0
41    Begin
42     Set   @Lev = @Lev + 1
43     Insert   @Tab (ID, PID, Name, Lev)
44     Select  ID, PID, Name,  @Lev   From  Tree  Where  ( @Lev = 1   and  ((PID = @ID or  ( @ID   is   null   and  PID  is   null )))  or  (PID  in  ( Select  ID  From   @Tab   Where  Lev = @Lev - 1 ))
45     order   by  ID
46    End
47    RETURN
48   END
49
50 GO
51
52 -- 实际数据
53 Insert  Tree(PID, Name)  values ( null , 公司)
54 Insert  Tree(PID, Name)  values ( 3 , IT)
55 Insert  Tree(PID, Name)  values ( 1 , Fin)
56 Insert  Tree(PID, Name)  values ( 5 , XZ)
57 Insert  Tree(PID, Name)  values ( 1 , HR)
58 GO
59
60

直接查询Select * from dbo.fGetTreeTable(null)就可以输入所有记录。


数据库技术就是一坛陈年老酒,越久越香,学以致用。
目录
相关文章
|
21天前
|
关系型数据库 MySQL 数据库
轻松入门MySQL:精准查询,巧用WHERE与HAVING,数据库查询如虎添翼(7)
轻松入门MySQL:精准查询,巧用WHERE与HAVING,数据库查询如虎添翼(7)
|
1月前
|
SQL 缓存 PHP
PHP技术探究:优化数据库查询效率的实用方法
本文将深入探讨PHP中优化数据库查询效率的实用方法,包括索引优化、SQL语句优化以及缓存机制的应用。通过合理的优化策略和技巧,可以显著提升系统性能,提高用户体验,是PHP开发者不容忽视的重要议题。
|
1月前
|
SQL 数据库 C#
C# .NET面试系列十一:数据库SQL查询(附建表语句)
#### 第1题 用一条 SQL 语句 查询出每门课都大于80 分的学生姓名 建表语句: ```sql create table tableA ( name varchar(10), kecheng varchar(10), fenshu int(11) ) DEFAULT CHARSET = 'utf8'; ``` 插入数据 ```sql insert into tableA values ('张三', '语文', 81); insert into tableA values ('张三', '数学', 75); insert into tableA values ('李四',
65 2
C# .NET面试系列十一:数据库SQL查询(附建表语句)
|
1月前
|
SQL 存储 JSON
阿里云数据库 SelectDB 内核 Apache Doris 2.1.0 版本发布:开箱盲测性能大幅优化,复杂查询性能提升 100%
亲爱的社区小伙伴们,Apache Doris 2.1.0 版本已于 2024 年 3 月 8 日正式发布,新版本开箱盲测性能大幅优化,在复杂查询性能方面提升100%,新增Arrow Flight接口加速数据读取千倍,支持半结构化数据类型与分析函数。异步多表物化视图优化查询并助力仓库分层建模。引入自增列、自动分区等存储优化,提升实时写入效率。Workload Group 资源隔离强化及运行时监控功能升级,保障多负载场景下的稳定性。新版本已经上线,欢迎大家下载使用!
阿里云数据库 SelectDB 内核 Apache Doris 2.1.0 版本发布:开箱盲测性能大幅优化,复杂查询性能提升 100%
|
1月前
|
存储 NoSQL Redis
【Redis】利用Redis List实现数据库分页快速查询
【Redis】利用Redis List实现数据库分页快速查询
100 0
|
1月前
|
存储 缓存 NoSQL
利用Redis List实现数据库分页快速查询的有效方法
利用Redis List实现数据库分页快速查询的有效方法
|
1月前
|
NoSQL Java 数据库连接
使用Java实现从数据库查出数据存入Redis,并在查询时先查Redis,如果Redis中没有数据再从数据库中读取
使用Java实现从数据库查出数据存入Redis,并在查询时先查Redis,如果Redis中没有数据再从数据库中读取
355 1
|
1月前
|
SQL 关系型数据库 MySQL
用 Python 连接数据库并进行查询。
【2月更文挑战第12天】【2月更文挑战第32篇】用 Python 连接数据库并进行查询。
|
1月前
|
存储 数据处理 数据库
构建高性能的数据库查询引擎
本文将介绍如何构建一个高性能的数据库查询引擎,以提升数据库查询的效率和响应速度。通过优化查询计划、索引设计和数据存储等方面,可以实现更快速和可扩展的数据库查询,为应用程序提供更好的用户体验和数据处理能力。
|
1天前
|
SQL Java 数据库连接
Java从入门到精通:2.3.2数据库编程——了解SQL语言,编写基本查询语句
Java从入门到精通:2.3.2数据库编程——了解SQL语言,编写基本查询语句

热门文章

最新文章