mysql 5.6 timestamp_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位小数的呢?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值