oracle用法集锦分析和总结.docx

  1. 1、本文档共31页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
一﹑ORACLE 查询树型关系(connect by prior star)t with connect by prior start经w常it会h被用到一个表中存在递归关系的时候。比如我们经常会将一个比较复杂的目录树存储到一个表中。或者将一些部门存储到一个表中,而这些部门互相有隶属关系。这个时候你就会用到 connect by prior star。t with 典型的使用方法就是: select * from table connect by prior cur_id=parent_id start with cur_id=??? 例如: a b 1 0 2 1 3 1 4 2 5 3 如果想查找 a=2 及其下面的所有数据,则: select * from table connect by prior a=b start with a=2 a b 2 1 4 2 例如 1﹕ 看成兩個集合 START WITH 為條件select * from dv_boms WHERE artic_code = 315066-001-00 AND PART_NO=00051 START WITH artic_code = 315066-001-00and bom_ver =1 AND ITEM_NO = 60 and item_no_pa insull CONNECT BY //以下條件為父主鍵=子主鍵 PRIOR artic_code =artic_code and PRIOR bom_verbo=m_ver and PRIOR item_no = item_no_pa; SELECT PART_NO,ITEM_NO,ITEM_NO_PA FROM DV_BOMS WHERE Artic_code = 315066-001-00and bom_ver =1; AND PART_NO=00051; 從那項開始找到底部關系圖select * from dv_boms START WITH artic_code = 315066-001-00and bom_ver =1 and item_no_pa =60 CONNECT BY PRIOR artic_code =artic_code and PRIOR bom_verbo=m_ver AND PRIOR ITEM_NO=ITEM_NO_PA; 例如 2﹕ select distinct artic_code,(case when level = 1 then part_no when level = 2 then||part_no when level = 3 then||part_no end ) part_no 此句也可 select artic_code, lpad( ,4*(level-1))||part_no part_no ,item_no,item_no_pa from dv_boms //where artic_code = 313324-002-00 connect by prior artic_code = artic_code and prior bom_ver = bom_ver and prior item_no = item_no_pa start with artic_code = 315066-001-00 and bom_ver =1 and PART_NO=00051 and item_no = 60 --从- 某一节点开始 ORDER BY part_no desc 例 3﹕ SELECT lpad( ,3 * level,P-AR2T)_ID ,level FROM BOM_DETAIL_NEW WHERE PRODUCT_ID = :ls_proc_id START WITH PARENT_PART_ID IS NULL CONNECT BY PRIOR PART_ID = PARENT_PART_ID; 例 3﹕ Oracle中使用 connect by来实现树状查询,其中可以使用 level这个伪列来实现分层查询。具体使用如下: 一张表 menu 记录菜单的层级情况。表结构如下: menu_id number, parent_idnumber, menu_name nvarchar2(20) 首先 select * from menu connect by menu_id = parent_id start with menu_id = 1; 这样可以看到 Oracle以树状结构产生结果。某些时候如果我只想要第 2 层的菜单项如何做呢。select * from (select level,menu_id,parent_id,menu_na

文档评论(0)

tianya189 + 关注
官方认证
内容提供者

该用户很懒,什么也没介绍

认证主体阳新县融易互联网技术工作室
IP属地上海
统一社会信用代码/组织机构代码
92420222MA4ELHM75D

1亿VIP精品文档

相关文档