首页 | 互联网 | IT动态 | IT培训 | Cisco | Windows | Linux | Java | .Net | Oracle | 软件测试 | C/C++ | 嵌入式开发 | 存储世界 | 服务器
网络设备 | IDC | 安全 | 求职招聘 | 数字网校 | 网页设计 | 平面设计 | 技术专题 | 电子书下载 | 教学视频 | 源码下载 | 搜索 | 博客 | 论坛
中国IT实验室Oracle频道
中国IT教育
Google
首页 入门基础 安装配置 体系架构 PLSQL 备份恢复 性能调优 开发技术 资讯动态 考试认证 下载 专题 讨论
您现在的位置: 中国IT实验室 >> Oracle >> 体系架构 >> 正文

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

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

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

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

[1] [2] 下一页

【责编:Chuan】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 专题推荐

 ·关于Java框架技术专题
 ·XML全攻略技术专题
 ·JAVA开源技术介绍专题
 ·Java嵌入式开发之J2ME技术专题
 ·超前体验 Oracle 11g的5个新特性…
 ·揭密使用VB.NET的五个实用技巧
 ·Oracle和SQL Server常用函数对比专题…
 ·展现C#世界 C#程序设计专题…
 ·Java入门 Tomcat的配置技巧精华专题…
 ·Oracle RMAN物理备份技术详解…
 今日更新
 社区讨论
 博客论点
 频道精选
 Oracle频道相关导航