千家信息网

Oracle group by与case when统一单位后统计数量

发表于:2024-09-21 作者:千家信息网编辑
千家信息网最后更新 2024年09月21日,表 数据select * from ware_info21 硫酸 1.0000 千克2 盐酸 2.0000 千克3 高锰酸钾 3.0000 吨4 高锰酸钾 4.0000 千克5 高锰酸钾 5000.0
千家信息网最后更新 2024年09月21日Oracle group by与case when统一单位后统计数量

数据
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 升

0