简单查询树形结构数据库表
2008-04-02 11:01:09来源:互联网 阅读 ()
在和同事Rock讨论中,得到一个思路,不用嵌套调用直接用一个语句就能够生成树,实事上他已做好了该程式,他用了临时表写了一个存储过程,我改写为一个表值函数,供大家参考:
表结构及表值函数如下:
查询树表语句
1/**//****** Object: Table [dbo].[Tree] Script Date: 2005-11-04 18:07:00 ******/ 2CREATE 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] 7GO 8 9 CREATE CLUSTERED INDEX [IX_Tree] ON [dbo].[Tree]([PID]) ON [PRIMARY] 10GO 11 12ALTER 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]) 18GO 19 20ALTER TABLE [dbo].[Tree] ADD 21 CONSTRAINT [FK_Tree_Tree] FOREIGN KEY 22 ( 23 [PID] 24 ) REFERENCES [dbo].[Tree] ( 25 [ID] 26 ) 27GO 28 29/**//****** 对象: 用户定义的函数 dbo.fGetTreeTable 脚本日期: 2005-11-04 18:07:02 ******/ 30CREATE FUNCTION dbo.fGetTreeTable 31 ( 32 @ID int= null 33 ) 34RETURNS @Tab TABLE(ID int, PID int, Name varchar(10), Lev int) 35AS 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 50GO 51 52--实际数据 53Insert Tree(PID, Name) values(null, 公司) 54Insert Tree(PID, Name) values(3, IT) 55Insert Tree(PID, Name) values(1, Fin) 56Insert Tree(PID, Name) values(5, XZ) 57Insert Tree(PID, Name) values(1, HR) 58GO |
直接查询Select * from dbo.fGetTreeTable(null)就能够输入任何记录。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
下一篇: SQL Server存储过程命名标准
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash