如何使用oracle sql将两列拆分为两行



例如,我有一个数据如下:

column1    column2      column3    column4     column5
A            B             5          2           3

我想要的表格是:

columnA
A             
B

确定拆分的条件是 if (column3 + column4)>5,否则不拆分。

union all

select column1 as columnA from t where column3 + column4 > 5 
union all
select column2 from t where column3 + column4 > 5 ;

我不确定我是否完全理解您要查找的内容,但是如果您想在 SELECT 中输入 if, ele,您可能不想使用 CASE 表达式。

https://docs.oracle.com/cd/B19306_01/server.102/b14200/expressions004.htm

对由 2 行组成的派生表使用 LEFT JOIN(带连接条件)或 CROSS JOIN(无连接条件),然后通过 case 表达式输出值。这两种方法也允许访问其他条件的所有列。

SQL 小提琴

Oracle 11g R2 架构设置

CREATE TABLE TABLE1
    (COLUMN1 VARCHAR2(1), COLUMN2 VARCHAR2(1), COLUMN3 INT, COLUMN4 INT, COLUMN5 INT)
;
INSERT ALL 
    INTO TABLE1 (COLUMN1, COLUMN2, COLUMN3, COLUMN4, COLUMN5)
         VALUES ('A', 'B', 5, 2, 3)
    INTO TABLE1 (COLUMN1, COLUMN2, COLUMN3, COLUMN4, COLUMN5)
         VALUES ('C', 'D', 1, 1, 1)
SELECT * FROM DUAL

查询 1

select
    case when lj.rn = 1 then t.column1 else t.column2 end as columnA
    , t.column1
    , t.column2
    , t.column3
    , t.column4
    , t.column5
from table1 t
left join ( select 1 as rn from dual union all select 2 from dual ) lj 
      on (column3 + column4) > 5 

结果

| COLUMNA | COLUMN1 | COLUMN2 | COLUMN3 | COLUMN4 | COLUMN5 |
|---------|---------|---------|---------|---------|---------|
|       A |       A |       B |       5 |       2 |       3 |
|       B |       A |       B |       5 |       2 |       3 |
|       D |       C |       D |       1 |       1 |       1 |

查询 2

select
    case when cj.rn = 1 then t.column1 else t.column2 end as columnA
    , t.column1
    , t.column2
    , t.column3
    , t.column4
    , t.column5
from table1 t
cross join ( select 1 as rn from dual union all select 2 from dual ) cj

结果

| COLUMNA | COLUMN1 | COLUMN2 | COLUMN3 | COLUMN4 | COLUMN5 |
|---------|---------|---------|---------|---------|---------|
|       A |       A |       B |       5 |       2 |       3 |
|       B |       A |       B |       5 |       2 |       3 |
|       C |       C |       D |       1 |       1 |       1 |
|       D |       C |       D |       1 |       1 |       1 |

假设我有包含示例数据的表test

column1  |  column2  |  column3  |  column4  |  column5  
-------------------------------------------------------  
A        |  B        |  5        |  2        |  3  
C        |  D        |  1        |  1        |  1  
E        |  F        |  4        |  5        |  1  

上述示例数据的脚本:-

CREATE TABLE TEST  
(  
 column1 VARCHAR2(10),  
 column2 VARCHAR2(10),  
 column3 NUMBER(2),  
 column4 NUMBER(2),  
 column5 NUMBER(2)  
);  
INSERT INTO TEST VALUES('A','B',5,2,3);  
INSERT INTO TEST VALUES('C','D',1,1,1);  
INSERT INTO TEST VALUES('E','F',4,5,1);  
COMMIT;  

下面的查询将给出所需的输出:-

WITH tmp AS  
(SELECT (CASE   
          WHEN column3 + column4 > 5 THEN  
            column1||','||column2  
          ELSE  
            NULL  
        END) columna,  
        column1,column2,column3,column4,column5  
  FROM TEST)  
SELECT regexp_substr(columna,'[^,]+',1,LEVEL) columna,  
       column1,column2,column3,column4,column5  
  FROM tmp  
CONNECT BY LEVEL <= regexp_count(columna, ',') + 1  
    AND PRIOR column1 = column1  
    AND PRIOR dbms_random.random IS NOT NULL;

输出:

columnA  |  column1  |  column2  |  column3  |  column4  |  column5  
-------------------------------------------------------------------  
A        |  A        |  B        |  5        |  2        |  3    
B        |  A        |  B        |  5        |  2        |  3  
         |  C        |  D        |  1        |  1        |  1  
E        |  E        |  F        |  4        |  5        |  1    
F        |  E        |  F        |  4        |  5        |  1  

最新更新