Oracle分栏(非分页)查询

不知道Oracle怎么进行数据分栏(分栏: 因数据列过长, 部分数据作为新列显示). 在这里先记录一下粗浅的查询方法.

数据源例子:

sql 复制代码
    select '日用百货' as cat, '手电筒' as name, 20 as amount, '2024-01-27' as dt from dual
    union all
    select '餐饮美食' as cat, '鸡公煲' as name, 15.9 as amount, '2024-01-27' as dt from dual
    union all
    select '餐饮美食' as cat, '海带粉' as name, 6 as amount, '2024-01-27' as dt from dual
    union all
    select '日用百货' as cat, '垃圾桶' as name, 9.9 as amount, '2024-01-26' as dt from dual
    union all
    select '日用百货' as cat, '大铁锅' as name, 66 as amount, '2024-01-26' as dt from dual
    union all
    select '日用百货' as cat, '电火锅' as name, 216 as amount, '2024-01-26' as dt from dual
    union all
    select '日用百货' as cat, '电饭锅' as name, 166 as amount, '2024-01-26' as dt from dual
    union all
    select '餐饮美食' as cat, '老乡鸡' as name, 19.9 as amount, '2024-01-26' as dt from dual
    union all
    select '日用百货' as cat, '塑料小板凳' as name, 8 as amount, '2024-01-26' as dt from dual
    union all
    select '日用百货' as cat, '垃圾袋' as name, 7.5 as amount, '2024-01-26' as dt from dual
    union all
    select '日用百货' as cat, '塑料靠背凳' as name, 10 as amount, '2024-01-26' as dt from dual
    union all
    select '日用百货' as cat, '鞋刷' as name, 4 as amount, '2024-01-26' as dt from dual
    union all
    select '日用百货' as cat, '撑衣杆' as name, 8.5 as amount, '2024-01-26' as dt from dual
    union all
    select '餐饮美食' as cat, '海带粉' as name, 6 as amount, '2024-01-26' as dt from dual

思路: 创造提取新列的条件, 然后进行关联查询

sql 复制代码
with t as (
    select '日用百货' as cat, '手电筒' as name, 20 as amount, '2024-01-27' as dt from dual
    union all
    select '餐饮美食' as cat, '鸡公煲' as name, 15.9 as amount, '2024-01-27' as dt from dual
    union all
    select '餐饮美食' as cat, '海带粉' as name, 6 as amount, '2024-01-27' as dt from dual
    union all
    select '日用百货' as cat, '垃圾桶' as name, 9.9 as amount, '2024-01-26' as dt from dual
    union all
    select '日用百货' as cat, '大铁锅' as name, 66 as amount, '2024-01-26' as dt from dual
    union all
    select '日用百货' as cat, '电火锅' as name, 216 as amount, '2024-01-26' as dt from dual
    union all
    select '日用百货' as cat, '电饭锅' as name, 166 as amount, '2024-01-26' as dt from dual
    union all
    select '餐饮美食' as cat, '老乡鸡' as name, 19.9 as amount, '2024-01-26' as dt from dual
    union all
    select '日用百货' as cat, '塑料小板凳' as name, 8 as amount, '2024-01-26' as dt from dual
    union all
    select '日用百货' as cat, '垃圾袋' as name, 7.5 as amount, '2024-01-26' as dt from dual
    union all
    select '日用百货' as cat, '塑料靠背凳' as name, 10 as amount, '2024-01-26' as dt from dual
    union all
    select '日用百货' as cat, '鞋刷' as name, 4 as amount, '2024-01-26' as dt from dual
    union all
    select '日用百货' as cat, '撑衣杆' as name, 8.5 as amount, '2024-01-26' as dt from dual
    union all
    select '餐饮美食' as cat, '海带粉' as name, 6 as amount, '2024-01-26' as dt from dual
)
, tmd as (
    select p.*
         , ceil(p.rn/3) as dv
         , mod(p.rn, 3) as md
    from (
         select row_number() over (partition by cat order by dt,amount desc) as rn, t.*
         from t
     ) p
)
select t1.cat
     , t1.name as name1,t1.amount as amount1
     , t2.name as name2,t2.amount as amount2
     , t3.name as name3,t3.amount as amount3
from (select * from tmd where md=1) t1
left join (select * from tmd where md=2) t2 on t1.cat=t2.cat and t1.dv=t2.dv
left join (select * from tmd where md=0) t3 on t1.cat=t3.cat and t1.dv=t3.dv
order by t1.cat,t1.dv,t1.md
;

查询结果:

CAT NAME1 AMOUNT1 NAME2 AMOUNT2 NAME3 AMOUNT3
日用百货 电火锅 216 电饭锅 166 大铁锅 66
日用百货 塑料靠背凳 10 垃圾桶 9.9 撑衣杆 8.5
日用百货 塑料小板凳 8 垃圾袋 7.5 鞋刷 4
日用百货 手电筒 20 NULL NULL NULL NULL
餐饮美食 老乡鸡 19.9 海带粉 6 鸡公煲 15.9
餐饮美食 海带粉 6 NULL NULL NULL NULL

后面再找时间研究吧. (2024-01-27)

相关推荐
崖山数据库系统YashanDB3 分钟前
YashanDB json语法
数据库
陈三一6 分钟前
关于多数据源下Spring声明式事务管理失效问题的分析与解决
数据库·spring
我有医保我先冲40 分钟前
SQL复杂查询与性能优化全攻略
数据库·sql·性能优化
烧瓶里的西瓜皮1 小时前
Go语言从零构建SQL数据库引擎(2)
数据库·sql·golang
SelectDB1 小时前
拉卡拉 x Apache Doris:统一金融场景 OLAP 引擎,查询提速 15 倍,资源直降 52%
大数据·数据库·数据分析
爱的叹息1 小时前
华为高斯(GaussDB) 集中式数据库 的开发技术手册,涵盖核心功能、开发流程、优化技巧及常见问题解决方案
数据库·gaussdb
背太阳的牧羊人1 小时前
使用 PyMuPDF(fitz)库打开 PDF 文件,并且是从内存中的字节流(BytesIO)读取 PDF 内容
数据库·pdf·文件处理·pymupdf·fitz
@淡 定3 小时前
MySQL MVCC 机制解析
数据库·mysql
Chandler243 小时前
Redis:内存淘汰原则,缓存击穿,缓存穿透,缓存雪崩
数据库·redis·缓存
SRC_BLUE_173 小时前
Python GUI 编程 | QObject 控件基类详解 — 定时器
开发语言·数据库·python