ITPUB论坛-中国最专业的IT技术社区

 手机号登录  找回密码
 注册
查看: 785|回复: 22

如何取出这几行数据?

[复制链接]
论坛徽章:
306
马上有钱
日期:2014-08-08 17:16:02路虎
日期:2014-02-13 10:34:03保时捷
日期:2014-02-14 09:46:462014年新春福章
日期:2014-02-18 16:41:11马上有车
日期:2014-02-18 16:41:11马上有车
日期:2014-02-19 11:55:14马上有房
日期:2014-02-19 11:55:14马上有钱
日期:2014-02-19 11:55:14马上有对象
日期:2014-02-19 11:55:14马上加薪
日期:2014-02-19 11:55:14
发表于 2018-4-13 16:38 | 显示全部楼层 |阅读模式
ORACLE 11204

当  FUSEORGID=11 时,取出
1  11
1  12
3  11
这3行记录,这里头的关键是,11 - > 1 -> 1(第2行) -> 12 ? 如何绕? 要求:  表只能读   “一次”。


论坛徽章:
306
马上有钱
日期:2014-08-08 17:16:02路虎
日期:2014-02-13 10:34:03保时捷
日期:2014-02-14 09:46:462014年新春福章
日期:2014-02-18 16:41:11马上有车
日期:2014-02-18 16:41:11马上有车
日期:2014-02-19 11:55:14马上有房
日期:2014-02-19 11:55:14马上有钱
日期:2014-02-19 11:55:14马上有对象
日期:2014-02-19 11:55:14马上加薪
日期:2014-02-19 11:55:14
 楼主| 发表于 2018-4-13 16:39 | 显示全部楼层
无标题_20180413.png

使用道具 举报

回复
论坛徽章:
186
红宝石
日期:2014-05-09 08:24:37萤石
日期:2014-01-03 10:25:39马上有钱
日期:2014-10-27 09:26:57马上有房
日期:2014-11-07 08:46:05马上有钱
日期:2014-11-12 09:33:24马上有钱
日期:2014-11-24 15:17:08马上有对象
日期:2015-01-14 17:33:15沸羊羊
日期:2015-02-11 09:07:41懒羊羊
日期:2015-03-04 09:03:43暖羊羊
日期:2015-03-04 14:50:37
发表于 2018-4-13 16:44 | 显示全部楼层
不理解什么意思...

使用道具 举报

回复
论坛徽章:
186
红宝石
日期:2014-05-09 08:24:37萤石
日期:2014-01-03 10:25:39马上有钱
日期:2014-10-27 09:26:57马上有房
日期:2014-11-07 08:46:05马上有钱
日期:2014-11-12 09:33:24马上有钱
日期:2014-11-24 15:17:08马上有对象
日期:2015-01-14 17:33:15沸羊羊
日期:2015-02-11 09:07:41懒羊羊
日期:2015-03-04 09:03:43暖羊羊
日期:2015-03-04 14:50:37
发表于 2018-4-13 16:47 | 显示全部楼层
考虑一下connect by看看.
select * from tt where FUSEORGID=11  connect by piror id=id;

使用道具 举报

回复
论坛徽章:
306
马上有钱
日期:2014-08-08 17:16:02路虎
日期:2014-02-13 10:34:03保时捷
日期:2014-02-14 09:46:462014年新春福章
日期:2014-02-18 16:41:11马上有车
日期:2014-02-18 16:41:11马上有车
日期:2014-02-19 11:55:14马上有房
日期:2014-02-19 11:55:14马上有钱
日期:2014-02-19 11:55:14马上有对象
日期:2014-02-19 11:55:14马上加薪
日期:2014-02-19 11:55:14
 楼主| 发表于 2018-4-13 16:59 | 显示全部楼层
lfree 发表于 2018-4-13 16:44
不理解什么意思...

先看2楼的图,再看一楼的要求,

使用道具 举报

回复
论坛徽章:
306
马上有钱
日期:2014-08-08 17:16:02路虎
日期:2014-02-13 10:34:03保时捷
日期:2014-02-14 09:46:462014年新春福章
日期:2014-02-18 16:41:11马上有车
日期:2014-02-18 16:41:11马上有车
日期:2014-02-19 11:55:14马上有房
日期:2014-02-19 11:55:14马上有钱
日期:2014-02-19 11:55:14马上有对象
日期:2014-02-19 11:55:14马上加薪
日期:2014-02-19 11:55:14
 楼主| 发表于 2018-4-13 17:02 | 显示全部楼层
lfree 发表于 2018-4-13 16:44
不理解什么意思...

如何读两次表,那肯定可以写出来,但效率就差了,我希望语句只读取表一次,就把这3条记录找出来,

使用道具 举报

回复
论坛徽章:
186
红宝石
日期:2014-05-09 08:24:37萤石
日期:2014-01-03 10:25:39马上有钱
日期:2014-10-27 09:26:57马上有房
日期:2014-11-07 08:46:05马上有钱
日期:2014-11-12 09:33:24马上有钱
日期:2014-11-24 15:17:08马上有对象
日期:2015-01-14 17:33:15沸羊羊
日期:2015-02-11 09:07:41懒羊羊
日期:2015-03-04 09:03:43暖羊羊
日期:2015-03-04 14:50:37
发表于 2018-4-13 19:41 | 显示全部楼层
ZALBB 发表于 2018-4-13 17:02
如何读两次表,那肯定可以写出来,但效率就差了,我希望语句只读取表一次,就把这3条记录找出来,

这样感觉我前面使用connect by 应该可以.

使用道具 举报

回复
论坛徽章:
186
红宝石
日期:2014-05-09 08:24:37萤石
日期:2014-01-03 10:25:39马上有钱
日期:2014-10-27 09:26:57马上有房
日期:2014-11-07 08:46:05马上有钱
日期:2014-11-12 09:33:24马上有钱
日期:2014-11-24 15:17:08马上有对象
日期:2015-01-14 17:33:15沸羊羊
日期:2015-02-11 09:07:41懒羊羊
日期:2015-03-04 09:03:43暖羊羊
日期:2015-03-04 14:50:37
发表于 2018-4-13 20:40 | 显示全部楼层
SCOTT@test01p> create table t (id number ,a number);
Table created.

insert into t values (1,11);
insert into t values (1,12);
insert into t values (2,12);
insert into t values (3,11);
commit ;

SCOTT@test01p> select * from t;
        ID          A
---------- ----------
         1         11
         1         12
         2         12
         3         11

--//要求输出:
        ID          A
---------- ----------
         1         11
         1         12
         3         11


2.测试:
SCOTT@test01p> select CONNECT_BY_ROOT(a) a_root, CONNECT_BY_ISLEAF isleaf, CONNECT_BY_ISCYCLE iscycle, t.* from t  connect by  nocycle prior id=  id  and prior a <> a start with a=11;
    A_ROOT     ISLEAF    ISCYCLE         ID          A
---------- ---------- ---------- ---------- ----------
        11          0          0          1         11
        11          1          1          1         12
        11          1          0          3         11

--//不知道是否符合需求.

使用道具 举报

回复
论坛徽章:
186
红宝石
日期:2014-05-09 08:24:37萤石
日期:2014-01-03 10:25:39马上有钱
日期:2014-10-27 09:26:57马上有房
日期:2014-11-07 08:46:05马上有钱
日期:2014-11-12 09:33:24马上有钱
日期:2014-11-24 15:17:08马上有对象
日期:2015-01-14 17:33:15沸羊羊
日期:2015-02-11 09:07:41懒羊羊
日期:2015-03-04 09:03:43暖羊羊
日期:2015-03-04 14:50:37
发表于 2018-4-13 20:44 | 显示全部楼层
感觉你的需求总之怪怪的.

使用道具 举报

回复
论坛徽章:
306
马上有钱
日期:2014-08-08 17:16:02路虎
日期:2014-02-13 10:34:03保时捷
日期:2014-02-14 09:46:462014年新春福章
日期:2014-02-18 16:41:11马上有车
日期:2014-02-18 16:41:11马上有车
日期:2014-02-19 11:55:14马上有房
日期:2014-02-19 11:55:14马上有钱
日期:2014-02-19 11:55:14马上有对象
日期:2014-02-19 11:55:14马上加薪
日期:2014-02-19 11:55:14
 楼主| 发表于 2018-4-14 19:50 | 显示全部楼层
lfree 发表于 2018-4-13 20:40
SCOTT@test01p> create table t (id number ,a number);
Table created.

为何得加这个条件 PRIOR A <> A ?

使用道具 举报

回复

您需要登录后才可以回帖 登录 | 注册

本版积分规则

TOP技术积分榜 社区积分榜 徽章 电子杂志 团队 统计 虎吧 老博客 知识索引树 读书频道 积分竞拍 文本模式 帮助
  ITPUB首页 | ITPUB论坛 | 数据库技术 | 企业信息化 | 开发技术 | 微软技术 | 软件工程与项目管理 | IBM技术园地 | 行业纵向讨论 | IT招聘 | IT文档 | IT博客
  ChinaUnix | ChinaUnix博客 | ChinaUnix论坛 | SAP ERP系统
CopyRight 1999-2011 itpub.net All Right Reserved. 北京盛拓优讯信息技术有限公司版权所有 联系我们 网站律师 隐私政策 知识产权声明
京ICP备16024965号 北京市公安局海淀分局网监中心备案编号:11010802021510 广播电视节目制作经营许可证:编号(京)字第1149号
  
快速回复 返回顶部 返回列表