[MySQL]如何将大数值带上 元,万,亿 这样的单位?
要解决的问题: 某表某字段用来表示交易金额,不同记录的金额相差很大,有的只有几元几角几分,有的却上亿.如果直接就把数值在页面上展示出来,则可读性不佳.因此我们需要将其单位展示出来,如1.23元,3.45万,4.56亿等.
解决方法:用case when判断数值所在区间,用convert函数将计算后的数值留下两位小数,用concat函数将计算后的数值和单位连接在一起.
形成的SQL语句是:
select id,value,(case when value<10000 then concat(convert(value,decimal(12,2)),'元')
when value<100000000 then concat(convert(value/10000,decimal(12,2)),'万')
else concat(convert(value/100000000,decimal(12,2)),'亿') end) as newCol from tb_number ;
执行效果:
mysql> select id,value,(case when value<10000 then concat(convert(value,decimal(12,2)),'元')
-> when value<100000000 then concat(convert(value/10000,decimal(12,2)),'万')
-> else concat(convert(value/100000000,decimal(12,2)),'亿') end) as newCol from tb_number ;
+----+------------------+--------------+
| id | value | newCol |
+----+------------------+--------------+
| 1 | 1.08 | 1.08元 |
| 2 | 12.08 | 12.08元 |
| 3 | 123.08 | 123.08元 |
| 4 | 1234.08 | 1234.08元 |
| 5 | 12345.08 | 1.23万 |
| 6 | 123456.08 | 12.35万 |
| 7 | 1234567.08 | 123.46万 |
| 8 | 12345678.08 | 1234.57万 |
| 9 | 123456789.08 | 1.23亿 |
| 10 | 1234567891.08 | 12.35亿 |
| 11 | 12345678912.08 | 123.46亿 |
| 12 | 123456789123.08 | 1234.57亿 |
| 13 | 1234567891234.08 | 12345.68亿 |
| 14 | 12345678912345.1 | 123456.79亿 |
| 16 | 123456789123456 | 1234567.89亿 |
+----+------------------+--------------+
15 rows in set (0.00 sec)
以上sql用到的表和数据:
create table tb_number(
id int primary key,
value double ) insert into tb_number(id,value) values('', '1.08');
insert into tb_number(id,value) values('', '12.08');
insert into tb_number(id,value) values('', '123.08');
insert into tb_number(id,value) values('', '1234.08');
insert into tb_number(id,value) values('', '12345.08');
insert into tb_number(id,value) values('', '123456.08');
insert into tb_number(id,value) values('', '1234567.08');
insert into tb_number(id,value) values('', '12345678.08');
insert into tb_number(id,value) values('', '123456789.08');
insert into tb_number(id,value) values('','1234567891.08');
insert into tb_number(id,value) values('','12345678912.08');
insert into tb_number(id,value) values('','123456789123.08');
insert into tb_number(id,value) values('','1234567891234.08');
insert into tb_number(id,value) values('','12345678912345.08');
insert into tb_number(id,value) values('','123456789123456.08');
--2020年5月8日--
[MySQL]如何将大数值带上 元,万,亿 这样的单位?的更多相关文章
- js转换金钱为中文单位元、万元、亿元、万亿
function unitConvert(num) { var moneyUnits = ["元", "万元", "亿元", "万 ...
- Asp.Net上传大文件带进度条swfupload
Asp.Net基于swfupload上传大文件带进度条百分比显示,漂亮大气上档次,大文件无压力,先看效果 一.上传效果图 1.上传前界面:图片不喜欢可以自己换 2.上传中界面:百分比显示 3.上传后返 ...
- mysql查询结果带上序号
select (@i:=@i+1) as rownum,t1.id ","from mega_user t1,(select @i:=0) t2 order by t1.gold ...
- Mysql千万级大表优化
Mysql的单张表的最大数据存储量尚没有定论,一般情况下mysql单表记录超过千万以后性能会变得很差.因此,总结一些相关的Mysql千万级大表的优化策略. 1.优化sql以及索引 1.1优化sql 1 ...
- MySQL优化十大技巧
转自:https://m.2cto.com/database/201701/557910.html MYSQL优化主要分为以下四大方面: 设计:存储引擎,字段类型,范式与逆范式 功能:索引,缓存,分区 ...
- 【优化】MySQL千万级大表优化解决方案
问题概述 使用阿里云rds for MySQL数据库(就是MySQL5.6版本),有个用户上网记录表6个月的数据量近2000万,保留最近一年的数据量达到4000万,查询速度极慢,日常卡死.严重影响业务 ...
- 30分钟玩转Net MVC 基于WebUploader的大文件分片上传、断网续传、秒传(文末附带demo下载)
现在的项目开发基本上都用到了上传文件功能,或图片,或文档,或视频.我们常用的常规上传已经能够满足当前要求了, 然而有时会出现如下问题: 文件过大(比如1G以上),超出服务端的请求大小限制: 请求时间过 ...
- 【转】JS大总结(带实例)
JS大总结(带实例) JavaScript事务查询综合click() 对象.click() 使对象被点击.closed 对象.closed 对象窗口是否已封闭true/falseclearTimeou ...
- vue大文件分片上传插件
最近遇见一个需要上传百兆大文件的需求,调研了七牛和腾讯云的切片分段上传功能,因此在此整理前端大文件上传相关功能的实现. 在某些业务中,大文件上传是一个比较重要的交互场景,如上传入库比较大的Excel表 ...
随机推荐
- SonarQube 自定义规则开发
SonarQube 自定义规则开发 满足一些特定需求的时候,需要自己开发代码规则. 环境 和前文的演示环境一致. 步骤 开发步骤见 Writing Custom Java Rules 101,这是官方 ...
- OGG复制进程延迟高,优化方法一(使用索引)
日常运维过程中,可能发现OGG同步进程延迟很高: 本篇介绍其中的一种方式. OGG复制进程,或者说同步进程及通过解析ogg trail文件,输出dml语句,在目标库执行dml操作,那么延迟高可能性其一 ...
- 2020-07-10:sql如何调优?
福哥答案2020-07-10:此答案来自群成员: SQL提高查询效率的几点建议 1.如果要用子查询,那就用EXISTS替代IN.用NOT EXISTS替代NOT IN.因为EXISTS引入的子查询只是 ...
- C#设计模式之9-装饰者模式
装饰者模式(Decorator Pattern) 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/405 访问. 装饰者模 ...
- Webpack 定义process.env的时机
定义 process.env的时机 如果已经提取了公共配置文件 webpack.common.js 分别定义了开发配置webpack.dev.js和生产配置webpack.prod.js 在webpa ...
- SpringMVC大威天龙
一 SpringMVC简介 SpringMVC是Spring提供的一个强大而灵活的Web框架 借助于注解 SpringMVC提供了几乎是POJO的开发模式 使得控制器的开发和测试更加简单 二 Spri ...
- 如何通过命令行简单的执行C程序
如何通过命令行简单的执行C语言编写的程序 首先,我们知道C语言程序都是以xxx.c结尾的,这在Windows系统和Linux系统都是一样的.其次,C程序的执行过程为四步:预处理--编译--汇编-- ...
- [netty4][netty-buffer]netty之池化buffer
PooledByteBufAllocator buffer分配 buffer分配的入口: io.netty.buffer.PooledByteBufAllocator.newDirectBuffer( ...
- SG 函数学习
\(Mex\) 运算 \(mex(S)\) 为不属于集合 \(S\) 的最小非负整数,即: \[mex(S)=\min \limits_{x \in \mathbb{N},x \not\in S} \ ...
- 精讲响应式webclient第1篇-响应式非阻塞IO与基础用法
笔者在之前已经写了一系列的关于RestTemplate的文章,如下: 精讲RestTemplate第1篇-在Spring或非Spring环境下如何使用 精讲RestTemplate第2篇-多种底层HT ...