mysql int存储时间格式_Mysql存储日期类型用int、timestamp还是datetime?

通常存储时间用datetime类型,现在很多系统也用int存储时间,它们有什么区别?个人更喜欢使用int这样对于日期计算时比较好哦,下面我们一起来看到底那种会好些。int(1).4个字节存储,INT的长度是4个字节,存储空间上比datatime少,int索引存储空间也相对较小,排序和查询效率相对较高一点点

(2)可读性极差,无法直观的看到数据,可能让你很恼火

TIMESTAMP

(1)4个字节储存

(2)值以UTC格式保存

(3)时区转化 ,存储时对当前的时区进行转换,检索时再转换回当前的时区。

(4)TIMESTAMP值不能早于1970或晚于2037

datetime

(1)8个字节储存

(2)与时区无关

(3)以'YYYY-MM-DD HH:MM:SS'格式检索和显示DATETIME值。支持的范围为'1000-01-01 00:00:00'到'9999-12-31 23:59:59'mysql也是这两年才流行,性能越来越来,具体怎么存储看个人习惯和项目需求吧

分享两篇关于int vs timestamp vs datetime性能测试的文章

Myisam:MySQL DATETIME vs TIMESTAMP vs INT 测试仪

CREATE TABLE `test_datetime` (

`id`int(10) unsigned NOT NULL AUTO_INCREMENT,

`datetime` FIELDTYPE NOT NULL,

PRIMARY KEY (`id`)

) ENGINE=MyISAM;

机型配置

kip-locking

key_buffer=128M

max_allowed_packet=1M

table_cache= 512sort_buffer_size=2M

read_buffer_size=2M

read_rnd_buffer_size=8M

myisam_sort_buffer_size=8M

thread_cache_size= 8query_cache_type= 0query_cache_size= 0thread_concurrency= 4测试

DATETIME14111 14010 14369 130000000TIMESTAMP13888 13887 14122 90000000INT13270 12970 13496 90000000执行mysql

mysql> select * from test_datetime into outfile ‘/tmp/test_datetime.sql’;

Query OK,10000000 rows affected (6.19sec)

mysql> select * from test_timestamp into outfile ‘/tmp/test_timestamp.sql’;

Query OK,10000000 rows affected (8.75sec)

mysql> select * from test_int into outfile ‘/tmp/test_int.sql’;

Query OK,10000000 rows affected (4.29sec)

alter table test_datetime rename test_int;

alter table test_int add column datetimeint INT NOT NULL;

update test_intset datetimeint =UNIX_TIMESTAMP(datetime);

alter table test_int drop column datetime;

alter table test_int change column datetimeint datetimeint not null;select * from test_int into outfile ‘/tmp/test_int2.sql’;

drop table test_int;

So now I have exactly the same timestampsfrom the DATETIME test, and it will be possible to reuse the originals for TIMESTAMP tests aswell.

mysql> load data infile ‘/export/home/ntavares/test_datetime.sql’ into table test_datetime;

Query OK,10000000 rows affected (41.52sec)

Records:10000000 Deleted: 0 Skipped: 0 Warnings: 0mysql> load data infile ‘/export/home/ntavares/test_datetime.sql’ into table test_timestamp;

Query OK,10000000 rows affected, 44 warnings (48.32sec)

Records:10000000 Deleted: 0 Skipped: 0 Warnings: 44mysql> load data infile ‘/export/home/ntavares/test_int2.sql’ into table test_int;

Query OK,10000000 rows affected (37.73sec)

Records:10000000 Deleted: 0 Skipped: 0 Warnings: 0As expected, since INTis simply stored as is whilethe others have to be recalculated. Notice how TIMESTAMP still performs worse, even though uses half of DATETIME storage size.

Let’s check the performance of full table scan:

mysql> SELECT SQL_NO_CACHE count(id) FROM test_datetime WHERE datetime > ‘1970-01-01 01:30:00′ AND datetime < ‘1970-01-01 01:35:00′;+———–+

| count(id) |

+———–+

| 211991 |

+———–+

1 row in set (3.93sec)

mysql> SELECT SQL_NO_CACHE count(id) FROM test_timestamp WHERE datetime > ‘1970-01-01 01:30:00′ AND datetime < ‘1970-01-01 01:35:00′;+———–+

| count(id) |

+———–+

| 211991 |

+———–+

1 row in set (9.87sec)

mysql> SELECT SQL_NO_CACHE count(id) FROM test_int WHERE datetime > UNIX_TIMESTAMP(’1970-01-01 01:30:00′) AND datetime < UNIX_TIMESTAMP(’1970-01-01 01:35:00′);+———–+

| count(id) |

+———–+

| 211991 |

+———–+

1 row in set (15.12sec)

Then again, TIMESTAMP performs worse and the recalculations seemed to impact, so the next good thing to test seemed to be without those recalculations: find the equivalents of those UNIX_TIMESTAMP() values, and use them instead:

mysql> select UNIX_TIMESTAMP(’1970-01-01 01:30:00′) AS lower, UNIX_TIMESTAMP(’1970-01-01 01:35:00′) AS bigger;+——-+——–+

| lower | bigger |

+——-+——–+

| 1800 | 2100 |

+——-+——–+

1 row in set (0.00sec)

mysql> SELECT SQL_NO_CACHE count(id) FROM test_int WHERE datetime > 1800 AND datetime < 2100;+———–+

| count(id) |

+———–+

| 211991 |

+———–+

1 row in set (1.94 sec)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值