mysql-时间戳为int字段,查询性能
发布时间:2020-12-11 23:24:52 所属栏目:MySql教程 来源:网络整理
导读:我将时间戳存储为int字段.在大表上,花时间太长才能在日期插入行,因为我正在使用mysql函数FROM_UNIXTIME. SELECT * FROM table WHERE FROM_UNIXTIME(timestamp_field,'%Y-%m-%d') = '2010-04-04' 有什么方法可以加快查询速度?也许我应该使用timestamp_field>
我将时间戳存储为int字段.在大表上,花时间太长才能在日期插入行,因为我正在使用mysql函数FROM_UNIXTIME.
有什么方法可以加快查询速度?也许我应该使用timestamp_field> = x AND timestamp_field< ?? 谢谢 编辑此查询的效果很好,但是您应该注意timestamp_field上的索引.
最佳答案
在常量上使用UNIX_TIMESTAMP,而不要在列上使用FROM_UNIXTIME:
这可以更快,因为它允许数据库使用列timestamp_field上的索引(如果存在).当您在列上使用非sargable函数(例如FROM_UNIXTIME)时,数据库将无法使用索引. 如果您在timestamp_field上没有索引,请添加一个. 完成此操作后,您还可以尝试通过选择所需的列而不是使用SELECT *来进一步提高性能. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |