0

0

MySQL时间戳转可读日期 where条件中时间范围查询实例

爱谁谁

爱谁谁

发布时间:2025-08-26 08:41:01

|

269人浏览过

|

来源于php中文网

原创

核心是使用from_unixtime()转换时间戳并在where中用unix_timestamp()转换比较值以利用索引,避免全表扫描,提升查询效率。

mysql时间戳转可读日期 where条件中时间范围查询实例

在MySQL中,将时间戳转换为可读日期,并在WHERE条件中进行时间范围查询,核心在于利用

FROM_UNIXTIME()
函数进行转换,然后与其他日期函数或比较运算符结合使用。这听起来简单,但实际操作中,尤其是在面对大量数据时,性能考量会变得非常重要。

解决方案

要将存储为UNIX时间戳的字段转换为可读日期,并在查询中筛选特定时间范围,最直接的方法是使用

FROM_UNIXTIME()
函数。

假设你有一个表

orders
,其中有一个
created_at
字段存储了订单创建时的UNIX时间戳(秒级)。

基本转换与查询:

SELECT
    order_id,
    FROM_UNIXTIME(created_at) AS readable_created_at,
    amount
FROM
    orders
WHERE
    FROM_UNIXTIME(created_at) BETWEEN '2023-01-01 00:00:00' AND '2023-01-31 23:59:59';

这段SQL会把

created_at
字段的值转换成
YYYY-MM-DD HH:MM:SS
格式,并在WHERE子句中对这个转换后的日期进行范围筛选。这在功能上是完全正确的,对于小数据量表,你可能感受不到什么问题。但经验告诉我,当表记录数达到几十万甚至上百万时,这种写法很可能会让你头疼,因为它会阻止MySQL使用
created_at
字段上的索引。

如何在WHERE子句中高效地查询时间戳范围?

说到性能,这是我个人在实际项目中踩过不少坑的地方。当你在

WHERE
子句中对索引列应用函数时,MySQL通常无法利用该列上的索引。这意味着它可能不得不进行全表扫描,这对于大数据集来说是灾难性的。

所以,更高效的做法是将你的比较值转换为时间戳,而不是转换你的时间戳列

SELECT
    order_id,
    FROM_UNIXTIME(created_at) AS readable_created_at, -- 这里仍然可以转换用于显示
    amount
FROM
    orders
WHERE
    created_at BETWEEN UNIX_TIMESTAMP('2023-01-01 00:00:00') AND UNIX_TIMESTAMP('2023-01-31 23:59:59');

这里我们使用了

UNIX_TIMESTAMP()
函数,它将一个可读的日期时间字符串转换为UNIX时间戳。这样一来,
WHERE
子句中的
created_at
字段保持了原始的数值形式,如果
created_at
列有索引,MySQL就能高效地利用这个索引进行范围查找,大大提升查询速度。这简直是天壤之别,尤其是在高并发的生产环境里,这一点优化可能就是系统能否稳定运行的关键。

处理不同精度时间戳(秒、毫秒)的查询差异与策略

一个常见的陷阱是,如果你的时间戳是以毫秒(或微秒)存储的,而不是标准的UNIX秒级时间戳。

FROM_UNIXTIME()
默认期望的是秒级时间戳。

如果你的

created_at
字段存储的是毫秒级时间戳(例如,Java或JavaScript中常见的
System.currentTimeMillis()
Date.now()
),那么你需要进行简单的数学运算:

XYZ SCIENCE
XYZ SCIENCE

免费论文AIGC检测,一键改写降AI率

下载

毫秒级时间戳转可读日期:

SELECT
    order_id,
    FROM_UNIXTIME(created_at / 1000) AS readable_created_at,
    amount
FROM
    orders;

WHERE
条件中进行范围查询时,同样要保持对索引友好的原则,将比较值转换为毫秒级时间戳:

SELECT
    order_id,
    FROM_UNIXTIME(created_at / 1000) AS readable_created_at,
    amount
FROM
    orders
WHERE
    created_at BETWEEN UNIX_TIMESTAMP('2023-01-01 00:00:00') * 1000 AND UNIX_TIMESTAMP('2023-01-31 23:59:59') * 1000;

这里

UNIX_TIMESTAMP()
返回的是秒级时间戳,所以需要乘以1000来匹配毫秒级的
created_at
字段。这种细节上的处理,往往决定了查询结果的正确性以及系统的健壮性。

除了FROM_UNIXTIME,还有哪些时间函数可以辅助时间戳查询?

MySQL提供了丰富的时间日期函数,它们可以与

FROM_UNIXTIME
结合使用,或者在某些场景下作为替代方案,实现更灵活的查询逻辑。虽然我们主要关注时间戳转换,但了解这些函数能让你在处理复杂时间需求时游刃有余。

  • DATE()
    /
    TIME()
    /
    YEAR()
    /
    MONTH()
    /
    DAY()
    /
    HOUR()
    /
    MINUTE()
    /
    SECOND()
    :
    这些函数可以从一个日期时间值中提取特定的部分。例如,如果你想查询某个特定月份的所有订单,可以这样做(虽然不推荐直接用于索引列):

    -- 性能不佳,但功能可行
    SELECT * FROM orders WHERE MONTH(FROM_UNIXTIME(created_at)) = 1 AND YEAR(FROM_UNIXTIME(created_at)) = 2023;

    更好的做法是转换边界值:

    SELECT * FROM orders WHERE created_at BETWEEN UNIX_TIMESTAMP('2023-01-01 00:00:00') AND UNIX_TIMESTAMP('2023-01-31 23:59:59');
  • DATE_FORMAT(date, format)
    : 这个函数允许你将日期时间值格式化为任意你想要的字符串格式。这对于报表输出或日志分析非常有用。

    SELECT order_id, DATE_FORMAT(FROM_UNIXTIME(created_at), '%Y年%m月%d日 %H时%i分%s秒') AS formatted_date FROM orders;
  • CURDATE()
    /
    NOW()
    :
    分别获取当前日期(不含时间)和当前日期时间。它们在构建动态查询范围时非常方便,比如查询“今天”或“过去24小时”的数据。

    -- 查询今天的所有订单(假设created_at是秒级时间戳)
    SELECT * FROM orders WHERE created_at >= UNIX_TIMESTAMP(CURDATE()) AND created_at < UNIX_TIMESTAMP(CURDATE() + INTERVAL 1 DAY);

    这种写法兼顾了可读性和性能,是我个人比较推崇的动态日期范围查询方式。

理解这些函数的组合使用,能够让你在处理各种时间戳和日期时间查询需求时,写出既高效又准确的SQL语句。关键在于,永远记住函数对索引列的影响,并优先考虑将比较值进行转换,而不是对索引列进行转换。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1090

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

380

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2008

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

379

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1560

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

438

2024.04.29

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

31

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Django 教程
Django 教程

共28课时 | 4.8万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.8万人学习

Kotlin 教程
Kotlin 教程

共23课时 | 4.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号