CTOCIO IT专家网

天极传媒 比特网 | 天极网 | IT专家网 | IT商网 | 52PK游戏网 | 手机天极 | IT分众 |
IT专家网搜索

数据库 | Oracle | DB2 | SQL Server | MySQL | 商业智能 | BI | DBA | Sybase| SQL Server 2008

您现在的位置: IT专家网 > 数据库子站 > 数据库技巧

在Oracle中选取有父子或树状关系的数据

作者: 小昭,  出处:赛迪网, 责任编辑: 王晓晨, 
2008-07-29 07:00
  我们在碰到数据结构的时候往往希望通过一次数据操作选取以某一条数据为切入点的全部相关数据。下面我们就介绍如何在Oralce中使用一条SQL语句从一个切入点获取该切入点的全部相关信息。

  子关系型纪录集或者树状关系数据记录集是我们在软件开发中一种较为常见的数据组织形式。例如办公系统中的组织架构,例如用户系统中的省份城市区域,例如电子商务网站中的产品分类,例如留言板系统中的留言回复关系,诸如此类。

  对于这一类型的数据我们常常会使用主从表或者主从字段的方法来满足结构上的需求。

  所谓主从表就是将各级数据分别存放在不同的数据表中(例如大类存放在一个数据表,小类存放在另一个数据表;又如省份存放一个数据表,城市存放在另一个数据表),但是这样有一个问题,就是数据有多少层就必须建立多少个数据表,这样不利于数据结构层次的扩展,比如电子商务网站中的产品,初期规划只有大类和小类,随着产品的增加却发现仅有大类和小类已经无法满足产品的分类需求,这时候会需要添加一个中类的概念,为了满足这个变化我们就需要新增一个中类的数据表,这样会造成较大的变更,所以我们说这种分表存放各级数据的设计有一定的局限性。而如果使用另外的一个解决办法-主从字段-则能够较好的解决这个问题,也就是说我们把省份和城市,产品的大类与小类,这些物理结构相同、逻辑结构不同的数据存放在同一个数据表中,以ID和ParentID两个字段来表明各条数据之间的逻辑关系。

  我们在碰到这种数据结构的时候往往希望通过一次数据操作选取以某一条数据为切入点的全部相关数据。例如访问一条科室的信息时,希望同时呈现该科室所在的处、部门信息,又例如获取一条BBS留言的时候,需要将其全部的回复以及各个回复的回复都一次选出,这都是最常见的需求。下面我们就介绍如何在Oralce中使用一条SQL语句从一个切入点获取该切入点的全部相关信息。下面我们将模拟一个BBS的留言与回复数据来说明这个SQL语句

  假设我们现在有如下结构的数据(T_Topic)

  TopicID ParentID TopicTitle

  1 null 请教Oracle选取树状数据

  2 1 re:请教Oracle选取树状数据

  3 1 其实只要这样就可以

  4 1 我也有同样的问题,学习

  5 1 顶!

  6 5 不要发垃圾贴哦~

  7 3 学习ing

  8 3 不是Oracle的方法呀

  9 6 我喜欢顶,咋地

  10 9 封号!

  大家注意看,上面的这些记录其实都是TopicID=1的纪录的相关记录(子记录或者孙记录,总归是后代记录)

  我们现在需要使用一条语句选择以TopicID为1记录的全部后代记录,请看下面的SQL: 

SELECT TopicID,ParentID,TopicTitle FROM T_TOPIC CONNECT BY PRIOR TopicID = ParentID START WITH TopciID = 1
共2页。 1 2 :

网友评论

笔名 
请您注意:遵守国家有关法律、法规,尊重网上道德,承担一切因您的行为而直接或间接引起的法律责任。    IT专家网友拥有管理笔名和留言的一切权利。
  • 周排行榜
  • 月排行榜

邮件订阅


    
天极服务 | 关于我们 | 网站律师 | 加入我们 | 联系我们 | 广告业务 | 友情链接 | 我要挑错
All Rights Reserved, Copyright 2004-2008, Ctocio.com.cn
渝ICP证B2-20030003号 如有意见请与我们联系 powered by 天极内容管理平台CMS4i