SQL实现根据类型对金额进行归类
sql
實現
資料庫
類型
進行
数据库:oracle 问题:在一张明细表里有一个字段表示类型,一个表示金额。现需要将几种类型的金额各合计为一种。 如现有如下数据: idtypeamount 1A100 1A20 1B20 1C10 2B150 2D50 3A50 3C10 3D20 ............ 变成 idtypyA_amounttypyB_amounttypyC_amountt
数据库:oracle问题:在一张明细表里有一个字段表示类型,一个表示金额。现需要将几种类型的金额各合计为一种。
如现有如下数据:
id type amount
1 A 100
1 A 20
1 B 20
1 C 10
2 B 150
2 D 50
3 A 50
3 C 10
3 D 20
............
变成
id typyA_amount typyB_amount typyC_amount typyD_amount
1 120 20 10
2 150 50
3 50 10 20
........
我的实现是使用union all构建一个临时表,然后再使用聚合完成。想问一下有没有更好的方法,这样速度应该不会很快的。请大神帮忙!!!!
select temp.id ,sum(temp.typyA_amount) as typyA_amount ,sum(temp.typyB_amount) as typyB_amount ,sum(temp.typyC_amount) as typyC_amount ,sum(temp.typyD_amount) as typyD_amount from (select t.id ,sum(t.A) as typyA_amount --A ,null as typyB_amount --B ,null as typyC_amount --C ,null as typyD_amount --D from table t where t.type ='A' group by t.id union all select t.id ,null as typyA_amount --A ,sum(t.B) as typyB_amount --B ,null as typyC_amount --C ,null as typyD_amount --D from table t where t.type ='B' group by t.id union all select t.id ,null as typyA_amount --A ,null as typyB_amount --B ,sum(t.C) as typyC_amount --C ,null as typyD_amount --D from table t where t.type ='C' group by t.id union all select t.id ,null as typyA_amount --A ,null as typyB_amount --B ,null as typyC_amount --C ,sum(t.D) as typyD_amount --D from table t where t.type ='D' group by t.id) temp
登入後複製
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前
By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
擊敗分裂小說需要多長時間?
3 週前
By DDD
R.E.P.O.保存文件位置:在哪里以及如何保護它?
3 週前
By DDD

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)