[20180415]如何取出这几行数据.txt

简介: [20180415]如何取出这几行数据.txt --//链接http://www.itpub.net/thread-2101289-1-1.html的讨论,测试看看. 1.

[20180415]如何取出这几行数据.txt

--//链接http://www.itpub.net/thread-2101289-1-1.html的讨论,测试看看.

1.环境:
SCOTT@book> @ ver1
PORT_STRING                    VERSION        BANNER
------------------------------ -------------- --------------------------------------------------------------------------------
x86_64/Linux 2.4.xx            11.2.0.4.0     Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production

SCOTT@book> 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);
insert into t values (3,15);
insert into t values (3,16);
commit ;


SCOTT@book> select * from t;
ID   A
--- ---
  1  11
  1  12
  2  12
  3  11
  3  15
  3  16
6 rows selected.

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

2.测试:
SCOTT@book> 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          0          0          3         11
        11          0          1          3         15
        11          1          1          3         16
        11          0          1          3         16
        11          1          1          3         15
7 rows selected.

--//可以发现还是不能满足需求.
SELECT CONNECT_BY_ROOT(a) a_root, CONNECT_BY_ISLEAF isleaf, CONNECT_BY_ISCYCLE iscycle, level,lpad(' ', level*2,' ')||a as c20, t.*
   FROM t
connect by nocycle prior id =  id
    AND prior a <> a
  start WITH a =  11;

    A_ROOT     ISLEAF    ISCYCLE      LEVEL C20                          ID          A
---------- ---------- ---------- ---------- -------------------- ---------- ----------
        11          0          0          1   11                          1         11
        11          1          1          2     12                        1         12
        11          0          0          1   11                          3         11
        11          0          1          2     15                        3         15
        11          1          1          3       16                      3         16
        11          0          1          2     16                        3         16
        11          1          1          3       15                      3         15
7 rows selected.

--//如何避免后面2行的输出.., 也就是如何避免从2层开始再探查.
SELECT CONNECT_BY_ROOT(a) a_root, CONNECT_BY_ISLEAF isleaf, CONNECT_BY_ISCYCLE iscycle, level,lpad(' ', level*2,' ')||a as c20, t.*
   FROM t
connect by nocycle prior id =  id
    AND prior a < a
  start WITH a =  11;

    A_ROOT     ISLEAF    ISCYCLE      LEVEL C20                          ID          A
---------- ---------- ---------- ---------- -------------------- ---------- ----------
        11          0          0          1   11                          1         11
        11          1          0          2     12                        1         12
        11          0          0          1   11                          3         11
        11          0          0          2     15                        3         15
        11          1          0          3       16                      3         16
        11          1          0          2     16                        3         16

6 rows selected.

--//还是不行,放弃!!简单一点加distinct.

SCOTT@book> select distinct id,a from (select CONNECT_BY_ROOT(a) a_root, CONNECT_BY_ISLEAF isleaf, CONNECT_BY_ISCYCLE iscycle,level, t.* from t  connect by  nocycle prior id=  id  and prior a <> a start with a=11) order by 1,2;
        ID          A
---------- ----------
         1         11
         1         12
         3         11
         3         15
         3         16

--//不知道还有好方法,放弃!!

目录
相关文章
|
1月前
|
C++
C++学习系列---读取文件名存入txt和从txt读取每行信息
C++学习系列---读取文件名存入txt和从txt读取每行信息
|
8月前
|
搜索推荐 Python
python将txt文档中的内容按字母顺序进行排序,并存入txt中
python将txt文档中的内容按字母顺序进行排序,并存入txt中
228 0
将文件a.txt的字符串前加上序号“1:”、“2:”、…。
将文件a.txt的字符串前加上序号“1:”、“2:”、…。
127 0
readline()函数:可以读取一行 分析: 1.创建一个file对象 2.使用循环读取每一行的内容 直到读取内容为空 3.将读取到的内容写
readline()函数:可以读取一行 分析: 1.创建一个file对象 2.使用循环读取每一行的内容 直到读取内容为空 3.将读取到的内容写
|
SQL 测试技术 索引
[20180509]函数索引问题.txt
[20180509]函数索引问题.txt https://jonathanlewis.wordpress.com/2018/05/07/fbis-dont-exist/ --//重复测试: 1.
1095 0
|
关系型数据库 Linux 索引
[20180212]函数索引问题.txt
[20180212]函数索引问题.txt --//11g下,如果函数索引,字段出现重复,出现ORA-54015: Duplicate column expression was specified.
981 0
|
索引 关系型数据库 Oracle
[20171202]关于函数索引的状态.txt
[20171202]关于函数索引的状态.txt --//我曾经在一篇贴子提到索引可以disable吗?链接: --//http://blog.itpub.net/267265/viewspace-2123537/ --//实际上仅仅函数索引能disable,为什么呢?实际上自己以前并不搞清楚实际上这个跟oracle使用函数的特殊性有关.
1212 0
|
数据库 关系型数据库 Oracle
[20161021]显示记录顺序问题.txt
[20161021]显示记录顺序问题.txt --同事在维护数据库时,发现记录显示顺序发生变化,看了一下操作过程,可以猜测可能维护后发生了行迁移导致的情况。 --通过例子说明: 1.
701 0