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

在MySQL中,将时间戳转换为可读日期,并在WHERE条件中进行时间范围查询,核心在于利用
FROM_UNIXTIME()
要将存储为UNIX时间戳的字段转换为可读日期,并在查询中筛选特定时间范围,最直接的方法是使用
FROM_UNIXTIME()
假设你有一个表
orders
created_at
基本转换与查询:
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
created_at
说到性能,这是我个人在实际项目中踩过不少坑的地方。当你在
WHERE
所以,更高效的做法是将你的比较值转换为时间戳,而不是转换你的时间戳列。
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()
WHERE
created_at
created_at
一个常见的陷阱是,如果你的时间戳是以毫秒(或微秒)存储的,而不是标准的UNIX秒级时间戳。
FROM_UNIXTIME()
如果你的
created_at
System.currentTimeMillis()
Date.now()
毫秒级时间戳转可读日期:
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()
created_at
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()
-- 查询今天的所有订单(假设created_at是秒级时间戳) SELECT * FROM orders WHERE created_at >= UNIX_TIMESTAMP(CURDATE()) AND created_at < UNIX_TIMESTAMP(CURDATE() + INTERVAL 1 DAY);
这种写法兼顾了可读性和性能,是我个人比较推崇的动态日期范围查询方式。
理解这些函数的组合使用,能够让你在处理各种时间戳和日期时间查询需求时,写出既高效又准确的SQL语句。关键在于,永远记住函数对索引列的影响,并优先考虑将比较值进行转换,而不是对索引列进行转换。
以上就是MySQL时间戳转可读日期 where条件中时间范围查询实例的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号