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

简介:   在与同事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)就可以输入所有记录。


数据库技术就是一坛陈年老酒,越久越香,学以致用。
目录
相关文章
|
1月前
|
SQL 数据库
LangChain-09 Query SQL DB With RUN GPT 查询数据库 并 执行SQL 返回结果
LangChain-09 Query SQL DB With RUN GPT 查询数据库 并 执行SQL 返回结果
32 2
|
11天前
|
SQL 安全 Java
MyBatis-Plus条件构造器:构建安全、高效的数据库查询
MyBatis-Plus 提供了一套强大的条件构造器(Wrapper),用于构建复杂的数据库查询条件。Wrapper 类允许开发者以链式调用的方式构造查询条件,无需编写繁琐的 SQL 语句,从而提高开发效率并减少 SQL 注入的风险。
11 1
MyBatis-Plus条件构造器:构建安全、高效的数据库查询
|
8天前
|
存储 缓存 固态存储
怎么让数据库查询更快
【10月更文挑战第28天】
18 2
|
10天前
|
存储 缓存 关系型数据库
怎么让数据库查询更快
【10月更文挑战第25天】通过以上综合的方法,可以有效地提高数据库查询的速度,提升应用程序的性能和响应速度。但在优化过程中,需要根据具体的数据库系统、应用场景和数据特点进行合理的调整和测试,以找到最适合的优化方案。
|
11天前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
180 1
|
11天前
|
SQL 关系型数据库 数据库
PostgreSQL性能飙升的秘密:这几个调优技巧让你的数据库查询速度翻倍!
【10月更文挑战第25天】本文介绍了几种有效提升 PostgreSQL 数据库查询效率的方法,包括索引优化、查询优化、配置优化和硬件优化。通过合理设计索引、编写高效 SQL 查询、调整配置参数和选择合适硬件,可以显著提高数据库性能。
79 1
|
30天前
|
SQL Java 数据库连接
如何使用`DriverManager.getConnection()`连接数据库,并利用`PreparedStatement`执行参数化查询,有效防止SQL注入。
【10月更文挑战第6天】在代码与逻辑交织的世界中,我从一名数据库新手出发,通过不断探索与实践,最终成为熟练掌握JDBC的开发者。这段旅程充满挑战与惊喜,从建立数据库连接到执行SQL语句,再到理解事务管理和批处理等高级功能,每一步都让我对JDBC有了更深的认识。示例代码展示了如何使用`DriverManager.getConnection()`连接数据库,并利用`PreparedStatement`执行参数化查询,有效防止SQL注入。
72 5
|
9天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
46 0
|
1月前
|
SQL 存储 安全
SQL查询数据库:基础概念与操作指南
在数字化时代,数据库已成为信息管理的重要工具之一。作为管理和操作数据库的核心语言,SQL(结构化查询语言)已成为数据管理和查询的关键技能。本文将全面介绍SQL查询数据库的基本概念、语句和操作指南,以帮助初学者快速上手,同时为进阶用户提供有价值的参考。一、数据库与SQL简介数据库是一种存储、管理和检索
37 3
|
10天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第26天】数据库作为现代应用系统的核心组件,其性能优化至关重要。本文主要探讨MySQL的索引策略与查询性能调优。通过合理创建索引(如B-Tree、复合索引)和优化查询语句(如使用EXPLAIN、优化分页查询),可以显著提升数据库的响应速度和稳定性。实践中还需定期审查慢查询日志,持续优化性能。
41 0
下一篇
无影云桌面