设为首页 收藏本站
查看: 1294|回复: 0

[经验分享] Oracle笔记:层次查询(Select)

[复制链接]

尚未签到

发表于 2016-7-21 06:57:03 | 显示全部楼层 |阅读模式
  基于树状结构的数据查询成为层次查询。
DSC0000.jpg
DSC0001.jpg
  层次化查询的基本语法
  

select 列名1,列名2 from 表名 start with 开始条件 connect by 递归条件
  如上图mark表,使用market_Id和parent_Market_Id将平行的数据变成了树状型。
  
  eg:查询表中所有亚洲的市场信息表。
  

select market_Id,market_Name from market start with market_Name = '亚洲' connect by prior market_Id = parent_Market_Id;
//start with market_Name = '亚洲'指查询的起始点为market = '亚洲',
//connect by prior market_id = paret_market_Id指前一条记录的market_Id等于后一条记录的parent_Market_Id;
//prior指定树的生成方式(后面详说)。
//查询的结果就为:亚洲,中国,韩国,朝鲜,北京。

  层次化查询的相关函数
  sys_connect_by_path(列名,分隔符):层次化查询总是以某条记录作为起始点,根据connect by指定的条件递归获得集合。此函数可对所查询的结果集进行聚合操作(仅限于字符串)。列名指定对那个列进行合并,分隔符则指定字符拼接在一起用的符号。
  

select market_Id,market_Name sys_connect_by_path(market_Name,'/') market_path from market start with market_Name = "北京" connect by prior parent_Market_Id = market_Id;
//prior很重要,如果没有这个字段,则只会显示第一条查询的内容,后面的不会显示了。

  
查询结果如下:
  
DSC0002.jpg
  max():获得最完整的路径:
  

select max(sys_connect_by_path(market_Name,'/')) market_path from market start with market_Name = "北京" connect by prior parent_Market_Id = market_Id;
//查询出的结果为上图第四条,也就是/北京/中国/亚洲/全球。

  
  二进制转十进制:
  实质就是从最后一位开始算,依次列为第0、1、2...位第n位的数(0或1)乘以2的n次方。
  如101,转换就是1*2的0次方+0*2的1次方+1*2的二次方=5.
  oralce自带函数bin_to_number();
  

select bin_to_num(1,0,1) a,bin_to_num(1,0) b from dual;

  SQL:

select sum(data) from (select substr('101',rownum,1) * power(2,length('101') - rownum) data from dual connect by rownum <= length('101')) ;
//substr(String , start_position,length) 取得字符串中指定起始位置和长度的字符串
//power(m,n) m的n次方
第一次循环括号里的时候,rownum=1,substr()函数取到得是1,power()取到的是4,所以整个select为4,第二次循环同上,为0,第三次为1,求sum为7。

  
  
  
  
  
  
  
  
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-247033-1-1.html 上篇帖子: ORACLE自定义datediff函数 下篇帖子: (转)oracle autotrace设置
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表