使用Oracle 10.2.0。Oracle - 多级自然排序行
我有一个由行号,缩进级别和文本组成的表格。我需要编写一个例程来'自然'对缩进级别内的文本进行排序[这是缩进级别较低的子节点]。我在分析例程方面经验有限,并且通过/之前进行连接,但是从我在这里和其他地方阅读的内容看来,似乎可以用它们来帮助我的事业,但我无法弄清楚。
CREATE TABLE t (ord NUMBER(5), indent NUMBER(3), text VARCHAR2(254));
INSERT INTO t (ord, indent, text) VALUES (10, 0, 'A');
INSERT INTO t (ord, indent, text) VALUES (20, 1, 'B');
INSERT INTO t (ord, indent, text) VALUES (30, 1, 'C');
INSERT INTO t (ord, indent, text) VALUES (40, 2, 'D');
INSERT INTO t (ord, indent, text) VALUES (50, 2, 'Z');
INSERT INTO t (ord, indent, text) VALUES (60, 2, 'E');
INSERT INTO t (ord, indent, text) VALUES (70, 1, 'F');
INSERT INTO t (ord, indent, text) VALUES (80, 2, 'H');
INSERT INTO t (ord, indent, text) VALUES (90, 2, 'G');
INSERT INTO t (ord, indent, text) VALUES (100, 3, 'J');
INSERT INTO t (ord, indent, text) VALUES (110, 3, 'H');
此:
SELECT ord, indent, LPAD(' ', indent, ' ') || text txt FROM t;
...的回报:选择
ORD INDENT TXT
---------- ---------- ----------------------------------------------
10 0 A
20 1 B
30 1 C
40 2 D
50 2 Z
60 2 E
70 1 F
80 2 H
90 2 G
100 3 J
110 3 H
11行。
在我为您定义的情况下,我需要我的程序设置ORD 60 = 50和ORD 50 = 60它们翻转],因为E是后d和Z之前
同样的,ORD 80和90 [90使100和110与它,因为它们属于它],100和110的最终输出应为:
ORD INDENT TXT
10 0 A
20 1 B
30 1 C
40 2 D
50 2 E
60 2 Z
70 1 F
80 2 G
90 3 H
100 3 J
110 2 H
其结果是,每个缩进级别按字母顺序排序,在其缩进级别内,在缩进级别内。
听起来像是给我的家庭作业。 – Gandalf 2009-10-27 20:29:36
似乎很难做家庭作业,但谁知道? – Lucero 2009-10-27 20:33:49
它不是一项家庭作业。我已经极大地简化了表格和数据,专注于答案,而不是无关的数据。 – user55904 2009-10-27 20:48:23