动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Oracle教程 ]的信息

本月文章推荐
.为何我的导出文件只有500K,导入时.
.ORACLE学习笔记--性能优化一.
.PL/SQL基本语法要素(组图).
.如何让文件系统自动mount后,还能.
.ORACLE SQL性能优化系列 (九).
.移植Oracle是这样做的.
.如何通过只读方式更改Oracle数据.
.数据库运行在非归档模式下,数据.
.Oracle中的用户创建和权限的分配.
.如何在Oracle中使用游标来实现多.
.数据仓库离我们到底有多远?.
.用DBMS_SYS_SQL包进行批量授权.
.ORACLE 11g新特性简介.
.Oracle冷备份的不完全恢复(二).
.CHAR,VARCHAR,VARCHAR2类型的区别.
.ORACLE问题与解答.
.简单介绍用RMAN进行Oracle自动备.
.如何安装使用Oracle10g.
.Oracle 10g基于Solaris 9 x86平台.
.Oracle数据库技术(34).

如何在Oracle层次查询中给SIBLINGS排序

发表日期:2008-4-28 |


Oracle SELECT语句中的START WITH和CONNECT BY子句自动阻断一个层次。缺少这项特性,就需要一个复杂的自联接来确定行之间的逻辑联系。START WITH子句指定被认为是层次起点,或“根”的一行或几行。然后CONNECT BY PRIOR子句指明哪些行彼此关联。

例如,列表A中的查询从Oracle HR样本模式的EMPLOYEES表中生成一个“Reports To”列表。

column "Reports To" format a30
set pagesize 9999

SELECT LPAD(' ', 2*(LEVEL-1))||last_name "Reports To", employee_id
FROM employees
START WITH employee_id IN (101, 102)
CONNECT BY PRIOR employee_id = manager_id
/

列表A

LEVEL伪列表明报告当前嵌套的深度,这里我使用LPAD雇员姓名对它们进行缩排。START WITH条件指出只有雇员101和102被认为是起点。然后CONNECT BY PRIOR子句将一行中的employee_id列与另一行的manager_id列连接起来,指出谁向谁报告。

如果你在HR模式中运行这个查询,你会注意到某个经理列表中的姓没有分类,它们以Oracle在处理层次时遇到它们的顺序排列。

如果你希望下属以字母顺序排列,你可以尝试对原始的last_name列使用ORDER BY。但是,这样会破坏层次,把它变回一个单调的姓名列表。

你还可以首先对伪列LEVEL使用ORDER BY,它说明某个特殊行在层次中的深度。这同样也会破坏层次,首先会列出所有的经理,然后是向他们报告的雇员。

在Oracle 10g(两个版本)中,现在很容易实现这一点:你可以使用新的SIBLINGS关键字建立正确的顺序。其语法如下:

ORDER SIBLINGS BY <expression>

因此在查询结尾处增加下面这个子句:

ORDER SIBLINGS BY last_name

将会保护层次,并在每个等级中以字母顺序排列雇员的姓。注意最初的last_name用作“Reports To”的别名。“Reports To”中的额外空间会影响排序,因此必须使用最初的last_name。列表B中是增加ORDER SIBLINGS BY前后的输出结果。

SQL> @siblings_without_orderby

Reports To                     EMPLOYEE_ID                                      
------------------------------ -----------                                      
Kochhar                            101                                      
Whalen                             200                                      
Mavris                             203                                      
Baer                               204                                      
Higgins                            205                                      
Gietz                              206                                      
Greenberg                          108                                      
Faviet                             109                                      
Chen                               110                                      
Sciarra                            111                                      
Urman                              112                                      
Popp                               113                                      
De Haan                            102                                      
Hunold                             103                                      
Ernst                              104                                      
Austin                             105                                      
Pataballa                          106                                      
Lorentz                            107                                      

18 rows selected.

SQL> @siblings_with_orderby

Reports To                     EMPLOYEE_ID                                      
------------------------------ -----------                                      
De Haan                            102                                      
Hunold                             103                                      
Austin                             105                                      
Ernst                              104                                      
Lorentz                            107                                      
Pataballa                          106                                      
Kochhar                            101                                      
Baer                               204                                      
Greenberg                          108                                      
Chen                               110                                      
Faviet                             109                                      
Popp                               113                                      
Sciarra                            111                                      
Urman                              112                                      
Higgins                            205                                      
Gietz                              206                                      
Mavris                             203                                      
Whalen                             200                                      

18 rows selected.

SQL>

列表B
上一篇:Oracle 10g中SCN与TimeStamp的斗转星移 人气:460
下一篇:详细讲解Oracle在Solaris下的性能与调整 人气:553
浏览全部Oracle的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-9-6 Movie34电影搜索引擎 v3.0
2008-9-6 wap2.0仿帝国建站喜用 v2.0
2008-9-6 免费人才招聘网 宽屏版 v3.01
2008-9-6 喜喔喔视频采集程序 v1.0 beta
2008-9-6 ASP客户管理系统
2008-9-6 主流驿站中秋祝福程序
2008-9-6 php实现msn协议的类
2008-9-5 Coppermine Photo Gallery v1.4.
2008-9-5 清松网络日记本 v2.4
2008-8-23 Mini WinMount V0.4
2008-8-23 Vista优化大师3.11正式版
2008-8-23 Wine 1.13
2008-8-23 KlipFolio 5.0 Build 5899-80
2008-8-23 Windows Sysinternals Desktops
2008-8-23 OneTap Movies1.2破解版
2008-8-23 AnnotaterPDF阅读1.1.503 破解版
2008-8-23 SoundMeter分贝测量仪 v1.0汉化破
2008-8-23 iDrum音乐节拍1.0破解版
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | Html转换js | js/vbs加密 | md5加密 | 进制转换
实用工具:汉字翻译拼音 | 符号对照表 | 个税计算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵