MySQL的一些小问题

本文深入解析数据库中不同字段类型的正确使用方法,包括decimal与float在数值存储上的区别,timestamp、int与varchar在时间戳存储的选择,以及varchar与char在字符串存储上的考量。

在建表的时候,总有一些模糊的点让我不得不百度:

1、金钱字段存储应当选择float、decimal、double?

应当选择decimal。

他是以字符串形式存储的,不会损失精度,为啥浮点型的(单精度、双精度)会损失精度呢,看下面的例子:
定点数如果不写精度和标度,则按照默认值decimal(10,0) 来操作,也就是存储11.1时候,会自动存储为11,(会自动四舍五入)如果11.9则是12

mysql> create table t1(c1 float(10,2), c3 decimal(10,2)); 
Query OK, 0 rows affected (0.02 sec)

mysql> insert into t1 values(9876543.21, 9876543.12);                   
Query OK, 1 row affected (0.00 sec)

mysql> select * from t1;                        
+----------------+-----------------+
| c1                | c3                   |
+----------------+-----------------+
| 9876543.00 | 9876543.12 | 
+----------------+------------------+
2 rows in set (0.00 sec)

详细解释:https://www.cnblogs.com/gsk99/p/5028817.html (比较复杂) https://www.cnblogs.com/gulibao/p/5416245.html (比较简单但未说明原理,从这里也可以看出如果decimal字段入的是截断后的值会产生警告并且浮点型在入库时候好像与decimal无异

但是在计算的时候会损失精度

2、时间戳选取使用varchar、int、timestamp?

三个都可以, int性能最好但是int的最大数值范围是2038年。时间戳选取timestamp,可以使用默认值为当前时间,并且入库入字符串型的时间,而非时间戳。顺便说一下timestamp比对大小也是直接字符串的

 

select count(*) from users where created_at<'2018-08-28 00:00:00' and created_at>='2018-08-01 00:00:00'

 

3、varchar和char该当如何选择?

varchar变长能省空间但是查找慢,char不省空间但是查找快

4、int(10)和varchar(20)以及float(10,2)、tiny(4)的建表用的数字是干啥的?

 int(10)这个数字设置不会影响该字段能够存储的大小,说是显示时候的长度控制,但是实际试验也没发现,这个不用管了

varchar和char设置的数字直接决定该字段能存储的字符串的字符数(5.0版本以上的是字符数,以下是字节数),比如char(3)可以存储abc但是无法存储abcd

float(m,d)之中,m是存储的内容最大整数数量,d是小数精度。比如float(7,4)小数点有四位,那么整数最多3个,也就是123.4567如果存储1234.1123,整数位数有4个,就会报错,小数点会自动四舍五入,decimal也一样

转载于:https://www.cnblogs.com/xuweiqiang/p/9809131.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值