sql 查询:无限极分类,获取父类下所有子类
如题,一个无限极分类的表,通过一个父类id,如何获取此父类下所有的子类??数据表:id,intnodename,varcharpid,int...
如题,一个无限极分类的表,通过一个父类id,如何获取此父类下所有的子类??
数据表:
id,int
nodename,varchar
pid,int 展开
数据表:
id,int
nodename,varchar
pid,int 展开
3个回答
展开全部
这问题很有趣哦!很多公司面试经常提到!有三种办法:
1.父类子类都各自建表(不推荐)
2.子类父类同在一张表(推介)
3.还有一种做法记不清了。
下面说说第二种做法吧!
你可以在数据库中建一张表都拥有以上的字段,然后在hibernate配置文件里配置一对多的关系,自己类对自己类做一对多的关联,具体配置你可以在一些论坛网站上搜到的。然后查询时你只要按id=父类的那个id去查一遍就全出来了.
1.父类子类都各自建表(不推荐)
2.子类父类同在一张表(推介)
3.还有一种做法记不清了。
下面说说第二种做法吧!
你可以在数据库中建一张表都拥有以上的字段,然后在hibernate配置文件里配置一对多的关系,自己类对自己类做一对多的关联,具体配置你可以在一些论坛网站上搜到的。然后查询时你只要按id=父类的那个id去查一遍就全出来了.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
如果在sql sever 2005或以上版本可以这样
with a as(
select id,nodename,pid from 表 where id='05009'
union all
select x.id,a.nodename,a.pid from 表 x,a
where x.pid=a.id)
select * from a
with a as(
select id,nodename,pid from 表 where id='05009'
union all
select x.id,a.nodename,a.pid from 表 x,a
where x.pid=a.id)
select * from a
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
我菜鸟,要好几句.写个递归,查一下类别下的所有子类然后select
*
from
文章
where
分类
in(,,,);
*
from
文章
where
分类
in(,,,);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询