前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识

一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识

原创
作者头像
骑马的少年
修改2021-05-28 18:09:52
9330
修改2021-05-28 18:09:52
举报
文章被收录于专栏:ApiPostApiPostApiPost

美好的周五

周五的早晨,一切都是那么美好。

一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识
一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识

然而,10点多的时候,运营小哥哥突然告诉我后台打不开了,我怀着一颗“有什么大不了的,估计又是(S)(B)不会连wifi”的心情,自信的打开了网址,果然,真打不开了。

一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识
一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识

这是存心让我过不好周末呀!

抓住那只bug

经过我缜密的排查,发现是一个“获取今天之前登录的用户”接口调用严重超时:

一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识
一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识

这个接口其实调用的数据表不多,在mysql只读取了1张表,表结构如下:

一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识
一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识

获取今天之前登录的用户列表的SQL如下:

SELECT u.email, log.user_id
FROM `user` u
LEFT JOIN `log_user_active` log ON u.user_id = log.user_id
WHERE log.`log_dtime` <1634567890
LIMIT 0 , 30

这只是一个简单的sql查询,并没有什么高精尖、复杂的查询为什么这么慢?由于log_user_active的数据量最大,所以猜想应该是log_user_active表出了问题,为了排查原因,我把SQL又简化了下,去掉了JOIN直接简化为:

SELECT log.user_id
FROM `log_user_active`
WHERE `log_dtime` <1551784072
LIMIT 0 , 30

经执行,这个语句花了将近1秒。。。如果多人同时访问,MySql不崩溃才怪。

一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识
一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识

此时,应该确信是这个表出问题无疑了,但是字段log_dtime明明建立了索引,怎么还这么慢呢?

经过各种百度,终于发现问题所在:由于log_dtime设计的是char类型。如果想让他走索引,查询的时候值必须要加引号,说明这是个字符串,否则是不会走索引的。我的数据恰巧都是数字组成(时间戳),查询的时候也没有刻意去加引号,导致查询的时候不走索引。

这就是问题所在了,于是进行如下尝试:

尝试1:

SQL的值加上引号

一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识
一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识

如上图,果然极快。

但是这样的话,需要改好多代码,我想想还是尝试下方法2吧。

尝试2:

果断将数据表结构log_dtime设计为INT型,如图:

一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识
一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识

再次执行SQL:

SELECT log.user_id
FROM `log_user_active`
WHERE `log_dtime` <1551784072
LIMIT 0 , 30

相应结果提升N倍:

一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识
一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识

至此,问题处理完毕。

总结

char类型字段想走索引的话,必须用引号括起来。如果是时间戳等类型的纯数字,建议还是存为int型吧。

一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识
一次事故,我对MySql时间戳存char(10)还是int(10)有了全新的认识

愉快的周末,又向我招手了。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 美好的周五
  • 抓住那只bug
  • 尝试1:
  • 尝试2:
  • 总结
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档