在建表的时候,总有一些模糊的点让我不得不百度:
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也一样