管理上有时会有需要,将字段上不相关的内容放入同一张报表。sql对于这种情况如何处理?举例如下,A表和B表通过现有字段是无法做表连接,实现下述效果的。
A业务表ta,字段c1原料、c2金额、c3税额
B业务表tb,字段c1成品、c2成本
实现效果
|----|----|----|----|----|
| A业务数据 ||| B业务数据 ||
| 原料 | 金额 | 税额 | 成品 | 成本 |
| | | | | |
| | | | | |
分析:不论是A表还是B表,在oracle数据库中都会有一列伪列,可以称为序号。按序号做连接,则可以实现上述效果。同时考虑到A表、B表数据的行数可能相同,也可能不同。连接时使用全连接。为了提高通用性,可以不使用oracle中专有的伪列,而是使用分析函数,其它数据库也有。
测试数据
create table ta (c1 varchar2(100), c2 number, c3 number);
insert into ta(c1,c2,c3) values('A', 100, 10);
insert into ta(c1,c2,c3) values('B', 150, 12);
create table tb (c1 varchar2(100), c2 number);
insert into tb(c1,c2) values('X', 50);
insert into tb(c1,c2) values('Y', 60);
insert into tb(c1,c2) values('Z', 80);
实现语句
select t1.c1 t1c1, t1.c2 t1c2, t1.c3 t1c3
,t2.c1 t2c1, t2.c2 t2c2
from (select
c1,c2,c3, row_number() over (order by c1) rownumber
from ta) t1
full join (select
c1,c2,row_number() over (order by c1) rownumber
from tb) t2
on t1.rownumber = t2.rownumber
效果如下
