sql树型应用总结

简介: sql树型应用总结
--测试数据
if object_id('[T]') is not null drop table [T]
create table [T] (ID int,PID int,NAME varchar(10))
insert into [T]
select 1,0,'A' union all
select 2,1,'B' union all
select 3,2,'C' union all
select 4,0,'D' union all
select 5,4,'E' union all
select 6,2,'F' union all
select 7,3,'G' union all
select 8,7,'H'
go

--获取所有的要根结点
select t.* from T t where exists (select 1 from T s where s.pid = t.id)
go

--获取所有的叶子结点
select t.* from T t where not exists (select 1 from T s where s.pid = t.id)
go

--获取树型记录的全路径

if object_id('[dbo].[getALLPath]') is not null
drop function [dbo].[getALLPath]
go
create function getALLPath()
returns @t table(id int,pid int,name varchar(50),path varchar(300))
as
begin
insert into @t select id,pid,name,null as path from T
update @t set path=name
DECLARE @i int,@j int
set @i=0
set @j=1
select @i=max(pid) from @t
while @j<=@i
begin
update v set path=a.path+'.'+v.name
from @t v inner join @t a on v.pid=a.id
where v.pid=@j
set @j=@j+1
end
return
end
go

select * from getALLPath()
go

--获取树型记录的全路径
if object_id('[dbo].[getpath]') is not null
drop function [dbo].[getpath]
go
create function getpath(@id varchar(20))
returns varchar(300)
as
begin
declare @s varchar(300)
select @s = name,@id = pid from T where id = @id
while exists (select 1 from T where id = @id )
select @s = name+'.'+@s,@id = pid from T where id = @id
return @s
end
go

select t.*,dbo.getpath(cast(id as varchar(20))) path from T
go

--查找树
if object_id('[dbo].[GetChild]') is not null
drop function [dbo].[GetChild]
go
create function GetChild(@id int)
returns @returnT table(pid int,id int,name varchar(50))
AS
begin
insert into @returnT select pid,id,name from T where id=@id
insert into @returnT select pid,id,name from T where pid=@id
while @@rowcount>0
insert into @returnT select A.pid,A.id,A.name
from T A inner join @returnT B on A.pid=B.id
where A.id not in(select id from @returnT)
return
end
go

select * from GetChild(1)
go

--查找树型记录的全路径
if object_id('[dbo].[getFindPath]') is not null
drop function [dbo].[getFindPath]
go
create function getFindPath(@parentId varchar(20))
returns @returndepartment table(id int,pid int,name varchar(50),path varchar(300))
as
begin
declare @t table(id int,pid int,name varchar(50),path varchar(300))
insert into @t select id,pid,name,null as path from T
update @t set path=name
DECLARE @i int,@j int
set @i=0
set @j=1
select @i=max(pid) from @t
while @j<=@i
begin
update v set path=a.path+'.'+v.name
from @t v inner join @t a on v.pid=a.id
where v.pid=@j
set @j=@j+1
end
insert into @returndepartment select * from @t where id=@parentId
insert into @returndepartment select * from @t where pid=@parentId
while @@rowcount>0
insert into @returndepartment select a.id,a.pid,a.name,a.path
from @t A inner join @returndepartment B on A.pid=B.id
where A.id not in(select id from @returndepartment)
return
end
go

select * from getFindPath(1)
go
目录
相关文章
|
1月前
|
SQL 存储 测试技术
SQL在构建系统中的应用:关键步骤与技巧
在构建基于数据库的应用系统时,SQL(Structured Query Language)作为与数据库交互的核心语言,扮演着至关重要的角色
|
14天前
|
SQL 数据库
如何应用SQL约束条件?
【10月更文挑战第28天】如何应用SQL约束条件?
32 11
|
1月前
|
SQL Oracle 关系型数据库
SQL语言的主要标准及其应用技巧
SQL(Structured Query Language)是数据库领域的标准语言,广泛应用于各种数据库管理系统(DBMS)中,如MySQL、Oracle、SQL Server等
|
7天前
|
SQL 监控 安全
员工上网行为监控软件:SQL 在数据查询监控中的应用解析
在数字化办公环境中,员工上网行为监控软件对企业网络安全和管理至关重要。通过 SQL 查询和分析数据库中的数据,企业可以精准了解员工的上网行为,包括基础查询、复杂条件查询、数据统计与分析等,从而提高网络管理和安全防护的效率。
20 0
|
1月前
|
SQL 数据库 数据库管理
数据库SQL函数应用技巧与方法
在数据库管理中,SQL函数是处理和分析数据的强大工具
|
1月前
|
SQL 存储 数据库
SQL在构建系统中的应用:关键要素与编写技巧
在构建基于数据库的系统时,SQL(Structured Query Language)扮演着至关重要的角色
|
1月前
|
SQL 关系型数据库 数据库
SQL数据库:核心原理与应用实践
随着信息技术的飞速发展,数据库管理系统已成为各类组织和企业中不可或缺的核心组件。在众多数据库管理系统中,SQL(结构化查询语言)数据库以其强大的数据管理能力和灵活性,广泛应用于各类业务场景。本文将深入探讨SQL数据库的基本原理、核心特性以及实际应用。一、SQL数据库概述SQL数据库是一种关系型数据库
49 5
|
1月前
|
SQL 存储 Oracle
Oracle数据库SQL语句详解与应用指南
在数字化时代,数据库已成为各类企业和组织不可或缺的核心组件。Oracle数据库作为业界领先的数据库管理系统之一,广泛应用于各种业务场景。掌握Oracle数据库的SQL语句是数据库管理员、开发人员及运维人员的基本技能。本文将详细介绍Oracle数据库SQL语句的基本概念、语法、应用及最佳实践。一、Or
52 3
|
1月前
|
SQL 数据库 索引
内连接(INNER JOIN)在SQL中的简单应用与技巧
在SQL查询中,内连接(INNER JOIN)是一种基本且常用的连接类型,用于从两个或多个表中检索匹配的记录
|
3月前
|
Java 前端开发 容器
Struts 2:在技术变革的风暴中航行,探索框架的革命性未来与创新融合之路
【8月更文挑战第31天】Struts 2作为一款成熟的企业级Java Web框架,凭借其稳定性和灵活性自2007年以来广受欢迎。它基于MVC设计模式,支持插件架构和RESTful服务,并能与Spring框架良好集成。然而,面对微服务架构和容器化技术(如Docker和Kubernetes)的兴起,Struts 2需提供更轻量级和支持指南来适应变化。通过深化与现代前端框架(如React和Vue.js)及AI技术的集成,并强化安全性与开发工具,Struts 2有望保持竞争力并迎接未来挑战。
47 0