最近在做项目的时候遇到一个表,将省市区都放到一个表里存储,通过父ID字段来表示省市区的关系. 创建表语句 CREATE TABLE [dbo].[Table_6]( [id1] [int] NOT NULL, [name] [varchar](50) NOT NULL, [id2] [int] NOT NULL ) ON [PRIMARY] 插入数据 insert Table_6 select 1,'江苏',0 union all select 2,'南京',1 union all select…
原文:在论坛中出现的比较难的sql问题:21(递归问题 检索某个节点下所有叶子节点) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路. 问题:求SQL:检索某个节点下所有叶子节点 部门表名:tb_department id int --节点id pid int --父节点id caption varchar…
数据库设计中经常碰到父子节点的关系结构,经常需要找到某个节点的根,或者某个节点的所有子节点,一般做法都是在业务层做递归的方式实现,或者数据库存储过程实现.但其实SQLServer提供的CTE可以很好的简化我们的工作,非常方便的实现这一功能. 例子: 1.正向递归,找某个节点下的所有子节点 with t as--如果CTE前面有语句,需要用分号隔断(selectId,ParentId,Name from WMS_Org whereId'union all select r1.Id,r1.Paren…