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

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


数据库技术就是一坛陈年老酒,越久越香,学以致用。
目录
相关文章
|
5月前
|
人工智能 安全 机器人
无代码革命:10分钟打造企业专属数据库查询AI机器人
随着数字化转型加速,企业对高效智能交互解决方案的需求日益增长。阿里云AppFlow推出的AI助手产品,借助创新网页集成技术,助力企业打造专业数据库查询助手。本文详细介绍通过三步流程将AI助手转化为数据库交互工具的核心优势与操作指南,包括全场景适配、智能渲染引擎及零代码配置等三大技术突破。同时提供Web集成与企业微信集成方案,帮助企业实现便捷部署与安全管理,提升内外部用户体验。
625 12
无代码革命:10分钟打造企业专属数据库查询AI机器人
|
7月前
|
Cloud Native 关系型数据库 分布式数据库
|
7月前
|
并行计算 关系型数据库 MySQL
如何用 esProc 将数据库表转储提速查询
当数据库查询因数据量大或繁忙变慢时,可借助 esProc 将数据导出为文件进行计算,大幅提升性能。以 MySQL 的 3000 万行订单数据为例,两个典型查询分别耗时 17.69s 和 63.22s。使用 esProc 转储为二进制行存文件 (btx) 或列存文件 (ctx),结合游标过滤与并行计算,性能显著提升。例如,ctx 并行计算将原查询时间缩短至 0.566s,TopN 运算提速达 30 倍。esProc 的简洁语法和高效文件格式,特别适合历史数据的复杂分析场景。
|
8月前
|
SQL 关系型数据库 MySQL
如何优化SQL查询以提高数据库性能?
这篇文章以生动的比喻介绍了优化SQL查询的重要性及方法。它首先将未优化的SQL查询比作在自助餐厅贪多嚼不烂的行为,强调了只获取必要数据的必要性。接着,文章详细讲解了四种优化策略:**精简选择**(避免使用`SELECT *`)、**专业筛选**(利用`WHERE`缩小范围)、**高效联接**(索引和限制数据量)以及**使用索引**(加速搜索)。此外,还探讨了如何避免N+1查询问题、使用分页限制结果、理解执行计划以及定期维护数据库健康。通过这些技巧,可以显著提升数据库性能,让查询更高效流畅。
|
8月前
|
数据库 Python
【YashanDB知识库】python驱动查询gbk字符集崖山数据库CLOB字段,数据被驱动截断
【YashanDB知识库】python驱动查询gbk字符集崖山数据库CLOB字段,数据被驱动截断
|
8月前
|
数据库
【YashanDB知识库】数据库用户所拥有的权限查询
【YashanDB知识库】数据库用户所拥有的权限查询
|
8月前
|
存储 运维 监控
百万指标,秒级查询,零宕机——时序数据库 TDengine 在 AIOps 中的硬核实战
本篇文章详细讲述了七云团队在运维平台中如何利用 TDengine 解决海量时序数据存储与查询的实际业务需求。内容涵盖了从数据库选型、方案落地到业务挑战及解决办法的完整过程,特别是分享了升级 TDengine 3.x 时的实战经验,给到有需要的小伙伴参考阅读。
324 1
|
8月前
|
缓存 NoSQL 关系型数据库
WordPress数据库查询缓存插件
这款插件通过将MySQL查询结果缓存至文件、Redis或Memcached,加速页面加载。它专为未登录用户优化,支持跨页面缓存,不影响其他功能,且可与其他缓存插件兼容。相比传统页面缓存,它仅缓存数据库查询结果,保留动态功能如阅读量更新。提供三种缓存方式选择,有效提升网站性能。
167 1
|
8月前
|
数据库
【YashanDB数据库】yasboot查询数据库状态时显示数据库状态为off
yasboot查询数据库状态时显示数据库状态为off