mysql-时间戳为int字段,查询性能

我将时间戳存储为int字段.在大表上,花时间太长才能在日期插入行,因为我正在使用mysql函数FROM_UNIXTIME.

SELECT * FROM table WHERE FROM_UNIXTIME(timestamp_field,'%Y-%m-%d') = '2010-04-04'

有什么方法可以加快查询速度?也许我应该使用timestamp_field> = x AND timestamp_field< ?? 谢谢 编辑此查询的效果很好,但是您应该注意timestamp_field上的索引.

SELECT * FROM table WHERE 
timestamp_field >= UNIX_TIMESTAMP('2010-04-14 00:00:00')
AND timestamp_field <= UNIX_TIMESTAMP('2010-04-14 23:59:59')
最佳答案
在常量上使用UNIX_TIMESTAMP,而不要在列上使用FROM_UNIXTIME:

SELECT * FROM table
WHERE timestamp_field
   BETWEEN UNIX_TIMESTAMP('2010-04-14 00:00:00')
       AND UNIX_TIMESTAMP('2010-04-14 23:59:59')

这可以更快,因为它允许数据库使用列timestamp_field上的索引(如果存在).当您在列上使用非sargable函数(例如FROM_UNIXTIME)时,数据库将无法使用索引.

如果您在timestamp_field上没有索引,请添加一个.

完成此操作后,您还可以尝试通过选择所需的列而不是使用SELECT *来进一步提高性能.

相关文章

在正式开始之前,我们先来看下 MySQL 服务器的配置和版本号信...
&gt; [合辑地址:MySQL全面瓦解](https://www.cnblogs.c...
物理服务机的CPU、内存、存储设备、连接数等资源有限,某个时...
1 回顾 上一节我们详细讲解了如何对数据库进行分区操作,包括...
navicat查看某个表的所有字段的详细信息 navicat设计表只能一...
文章浏览阅读4.3k次。转载请把头部出处链接和尾部二维码一起...