您好,欢迎访问一九零五行业门户网

sql 多级分类的级联查询

分类是在一般系统最常见的信息组织方式,有单级的分类,二级的分类,还有无限制级的分类。
当然我们给博客贴上分类的时候只要join下就可以找到分类的名称。
但是我们在做导航或者选择分类的时候往往涉及到分类的级联查询。下面就是说如何用sql查询这样的分类信息。
7 -- 建立分类表 
 代码如下 复制代码
create table t_category
(
    id int identity(1,1) primary key,
    name varchar(40) not null,
    parentid int default(-1)
)
?-- 插入一些测试数据 
insert into t_category(name) values('计算机类')
insert into t_category(name) values('吃的类')
insert into t_category(name, parentid) values('linux', 1)
insert into t_category(name, parentid) values('python', 1)
insert into t_category(name, parentid) values('oracle', 1)
insert into t_category(name, parentid) values('水果', 2)
insert into t_category(name, parentid) values('主食', 2)
insert into t_category(name, parentid) values('米饭', 7)
insert into t_category(name, parentid) values('面食', 7)
insert into t_category(name, parentid) values('django', 4)
insert into t_category(name, parentid) values('tornado', 4)
?-- 问题一:如何检索一个分类的路线 即:父->子->子->子 获得这样一个路径
-- 查询django分类的路径 结果应该为计算机类->python->django
代码如下 复制代码
with ctetable(id,name,pid) as (
    select id,name, parentid from t_category where id = 10
    union all
    select p2.id, p2.name, parentid from ctetable join t_category p2 on p2.id =ctetable.pid 
)
select * from ctetable order by id
?-- 输出结果 
1, '计算机类', -1
4, 'python', 1
10, 'django', 4
其它类似信息

推荐信息