Oracle group by与case when统一单位后统计数量
更新:HHH   时间:2023-1-7


数据
select * from ware_info2 
1 硫酸 1.0000 千克
2 盐酸 2.0000 千克
3 高锰酸钾 3.0000
4 高锰酸钾 4.0000 千克
5 高锰酸钾 5000.0000 毫升
6 高锰酸钾 6.0000
7 高锰酸钾 7.0000

将毫升转换成升,吨转换成千克,汇总数据
select name,sum(
case
when unit='吨' then qty*1000
when unit='毫升' then qty/1000
else qty end), 
case 
when unit='吨' then '千克'
when unit='毫升' then '升'
when unit='升' then '升'
when unit='千克' then '千克'
 end as unit
from ware_info2
group by name,case 
when unit='吨' then '千克'
when unit='毫升' then '升'
when unit='升' then '升'
when unit='千克' then '千克'
end 
结果:
高锰酸钾 3004 千克
硫酸 1 千克
盐酸 2 千克
高锰酸钾 18

返回关系型数据库教程...