Mysql5.6之后的timestamp底层是用什么存储的?

发现了mysql5.6版本之后timestamp的一个有趣问题,具体如下:

mysql> desc test_idx;
+--------+--------------+------+-----+---------+----------------+
| Field  | Type         | Null | Key | Default | Extra          |
+--------+--------------+------+-----+---------+----------------+
| id     | int(11)      | NO   | PRI | NULL    | auto_increment |
| name   | varchar(255) | NO   |     | NULL    |                |
| sid    | int(11)      | NO   | UNI | NULL    |                |
| time_1 | timestamp(6) | YES  |     | NULL    |                |
| time_2 | timestamp(2) | YES  |     | NULL    |                |
| time_3 | timestamp(4) | YES  |     | NULL    |                |
| time_4 | timestamp    | YES  |     | NULL    |                |
+--------+--------------+------+-----+---------+----------------+
7 rows in set (0.00 sec)

mysql> select * from test_idx;
+----+------+-----+----------------------------+------------------------+--------------------------+---------------------+
| id | name | sid | time_1                     | time_2                 | time_3                   | time_4              |
+----+------+-----+----------------------------+------------------------+--------------------------+---------------------+
|  2 | zhao |   1 | 2018-09-20 20:39:59.000000 | 2018-09-20 20:40:05.00 | 2018-09-20 20:40:09.0000 | 2018-09-20 20:40:55 |
+----+------+-----+----------------------------+------------------------+--------------------------+---------------------+
1 row in set (0.00 sec)

问题描述:当建表的时候指定了timestamp的长度(最大为6)的时候,timestamp是可以保持小数后6位的,这6位小数按照官方文档描述是微秒单位。

疑问:是不是说5.6之后timestamp是精确到微秒的,再有timestamp占4个字节,那么底层是怎么存储这6位小数的呢?

阅读 3.2k
1 个回答

clipboard.png

clipboard.png

例如TIME(0), TIME(2), TIME(4), and TIME(6) 分别用3, 4, 5, and 6 bytes

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题