
用分为单位可以用int型,比较好计算,但是一般用户输入个显示的单位都是元,需要转换比较繁琐。
大家一般用什么作单位的?
1 Septembers 2015-06-17 12:39:32 +08:00 via Android 您在做死 |
2 neoblackcap 2015-06-17 12:42:35 +08:00 用精确的数据类型存储,你的数据类型若是能精确保存分数比如1/3之类的,你用什么单位都一样。 若是不能就乖乖地用分对应整型或者长整型来保存,反正微信那边的人是这样做。 |
3 vinsony OP 我现在用的很黄很暴力的varchar....单位是元.. |
4 Mutoo 2015-06-17 12:49:59 +08:00 decimal <- 正解 如果不做汇率转换,直接用元就行了。 |
5 love 2015-06-17 12:51:09 +08:00 Javascript中的计算呢?用int? 毕竟0.1 + 0.1 + 0.1 !== 0.3有时也要命的 |
6 bigdude 2015-06-17 12:51:48 +08:00 decimal啊 |
7 jedrek 2015-06-17 12:53:54 +08:00 《高性能MySQL》中建议用整数类型保存,必要的时候移动小数点即可 |
8 quix 2015-06-17 15:10:02 +08:00 支持ls , 用 decimal, 本质是用字符串保存的数字 |
9 mahone3297 2015-06-17 15:11:20 +08:00 建议整形。。。 |
10 davidyin 2015-06-17 15:15:23 +08:00 整数,到分 |
11 learnshare 2015-06-17 15:44:09 +08:00 用分的整数比较好 |
12 garfeildma 2015-06-17 17:03:32 +08:00 整数,分,用decimal才是作死 |
13 xmbaozi 2015-06-17 17:07:27 +08:00 用分的话 万一哪个地方忘了转换成元岂不是悲剧 |
14 b821025551b 2015-06-17 17:07:32 +08:00 精确到毫,用long存储;流水大业务复杂的话用分存误差太大。 |
15 b821025551b 2015-06-17 17:12:47 +08:00 @xmbaozi 养成习惯就好了,前公司所有的金额字段都是精确到毫,各种计算按豪,只有最后展示或调用支付宝api才格式化成元。 |
16 keary 2015-06-17 17:21:31 +08:00 看你的业务需要了,如果需要考虑以后支持不同币种的话,务必使用decimal;如果只支持人民币单一币种就直接int或者long就可以了。 |
17 vinsony OP @b821025551b 经常有网站超低价卖东西,可能就是忘了多按两个零.... o(∩_∩)o |
18 loveuqian 2015-06-17 18:45:55 +08:00 用String最好。。。。。23333 |
19 lilydjwg 2015-06-17 19:24:48 +08:00 @quix decimal,至少是正确实现的 decimal,是使用十进制数的。而且其运算 CPU 也有直接支持。 @neoblackcap 金融很少有需要使用分数的情况吧。大部分情况都是精确到分,比如某商品三件一块钱,那么买一件就是 0.33RMB,两件就是 0.67RMB。 @xmbaozi 除了调试的时候,你应该只有一个地方来做这种转换。 通常表示价格的需求,定点数最好。 |
20 arslion 2015-06-17 19:28:19 +08:00 分(认真脸) |
21 quix 2015-06-17 19:59:13 +08:00 @lilydjwg 查了一下文档, mysql 5.0.3之前的版本确实是用string 储存的, 现在确实都是使用binary保存了. |
22 imn1 2015-06-17 20:10:51 +08:00 用分是肯定不够的,除非纯粹只是显示 别说证券、汇率用到厘的情况很多,即使一般财务做一些统计学计算,那时发现只到分是很头痛的事 |
23 neoblackcap 2015-06-17 22:11:20 +08:00 @lilydjwg 这高精度的数据结构就好。因为单看int我都不知道楼主在说哪个领域,数据库还是编程语言,好比C就没有原生的decimal但有int。 |
24 shakoon 2015-06-17 22:12:42 +08:00 银行用number(22,2) |
25 lujiajing1126 2015-06-17 22:35:51 +08:00 我司用的都是分 用64位的系统,Java的话货币可以用BigDecimal,c,cpp可以用long或者long long吧,sql(mysql,hive)里面BigInt 至于Javascript。。。。没办法。。你就用字符串吧。。 |
26 ryd994 2015-06-17 22:54:15 +08:00 除了输出的时候/100其他时候根本不用转换 有什么繁琐的? |
27 lilydjwg 2015-06-18 07:37:13 +08:00 @lujiajing1126 C 可以用 mpdecimal 的。Java 都有库的东西 C 和 C++ 不太可能没有。 @quix MySQL 还真拿过字符串表示十进制数啊,这 My- 前缀再一次被表现了 :-D |