0

我有一个如下所示的输入数据集:

header1,null,null,null
null,1,X,Y,Z
null,2,X,Y,Z
null,3,X,Y,Z
header2,null,null,null
null,4,X,Y,Z
null,5,X,Y,Z
null,6,X,Y,Z

我想针对该输入编写一个查询,以返回如下所示的结果集:

header1,1,X,Y,Z
header1,2,X,Y,Z
header1,3,X,Y,Z
header2,4,X,Y,Z
header2,5,X,Y,Z
header2,6,X,Y,Z

我在 Oracle 11g R2 上。我一直在查看此处的 Oracle 分析介绍: http ://www.oracle-base.com/articles/misc/analytic-functions.php

我在想有一个解决方案,但我还没有找到。我认为的问题是我没有什么可以真正分组的。我唯一的“指标”是重复标头值直到我遇到一组空值,然后抓取下一个标头并重复它直到我遇到一些空值。所以顺序很重要,但是您可以看到我们没有要排序的列。

下面是一些用于构建测试表和插入行的快速脚本。

谢谢。

create table test (
col01 varchar2(10),
col02 varchar2(10),
col03 varchar2(10),
col04 varchar2(10))

insert into test values ('header1',null,null,null);
insert into test values (1,'X','Y','Z');
insert into test values (2,'X','Y','Z');
insert into test values (3,'X','Y','Z');
insert into test values ('header2',null,null,null);
insert into test values (4,'X','Y','Z');
insert into test values (5,'X','Y','Z');
insert into test values (6,'X','Y','Z');
4

2 回答 2

2

LAG是答案,但您需要依靠行总是以相同的顺序出现,然后您可以使用rowid.

看看SQL Fiddle

select * 
  from
    (select case when header is null
                 then lag(header ignore nulls) over (order by rowid) 
             end header,col01,col02,col03,col04
       from
       (select case when col01 like 'header%' 
                    then col01 
                end header,col01,col02,col03,col04
        from test) 
    )
where header is not null

我希望这是一次处理表并将其带入适当的数据模型,因为表设计不是很好,但我想你已经知道了。

于 2012-09-26T20:44:09.240 回答
2

尝试这个

WITH CTE AS (
SELECT COL01, COL02, COL03, COL04, 
CASE WHEN COL01 LIKE 'header%' THEN col01 else null END NEW_COL01
FROM TESTTable
)

SELECT * FROM (
SELECT COL01, COL02, COL03, COL04, 
CASE WHEN NEW_COL01 IS NULL 
THEN LAG(NEW_COL01 IGNORE NULLS) OVER (ORDER BY ROWID) END HEAD_COL
FROM CTE
) WHERE col01 not like 'header%';
于 2012-09-26T16:32:49.740 回答