MySQL中的 UNIX_TIMESTAMP 函数使用总结(附详例)

本文介绍了MySQL中如何使用UNIX_TIMESTAMP()函数进行时间戳转换,包括秒级和毫秒级的时间戳转换方法,并展示了如何利用这些转换进行精确的时间范围查询。

背景

在测试过程中,一些基础的SQL查询可能需要加上一些查询条件,这次遇到了一个时间查询,但时间格式并不是:“年-月-日 小时:分:秒”这样的格式,而是时间戳的格式,找寻了一些资料,加上我们开发同学的指导,成功搜索出预期想要的数据,现将MySQL 中的**UNIX_TIMESTAMP()**使用总结在此~

UNIX_TIMESTAMP

1、查询出 时间:2020-12-22 00:00:00 转时间戳 (秒级)

-- 查询出 时间:2020-12-22 00:00:00 转时间戳 (秒级)
SELECT UNIX_TIMESTAMP('2020-12-22 00:00:00')

在这里插入图片描述

2、查询出 时间:2020-12-22 00:00:00 转时间戳 (毫秒级)

-- 查询出 时间:2020-12-22 00:00:00 转时间戳 (毫秒级)
SELECT UNIX_TIMESTAMP('2020-12-22 00:00:00')*1000

在这里插入图片描述
3、-查询出 create_time 时间在今天(2020-12-22 - 2020-12-23)的数据

-- 查询出 create_time时间在今天(2020-12-22 - 2020-12-23)的数据
SELECT * FROM def_user_event_log e WHERE
e.create_time >=UNIX_TIMESTAMP('2020-12-22 00:00:00')*1000
AND e.create_time <=UNIX_TIMESTAMP('2020-12-23 00:00:00')*1000

在这里插入图片描述
4、查询指定字段中包含某个时间戳(毫秒级)

-- 查询出 指定字段中包含某个时间戳
SELECT * FROM def_request_log req WHERE
req.request_query_param 
LIKE CONCAT('%',(UNIX_TIMESTAMP('2020-12-21 00:00:00')*1000),'%')

在这里插入图片描述

MySQL 中的 `UNIX_TIMESTAMP` 函数用于将日期时间值转换为 UNIX 时间戳。UNIX 时间戳表示自 1970-01-01 00:00:00 UTC 以来的秒数,是一个整数形式的时间表示方式,广泛用于时间的计算和存储。以下是关于 `UNIX_TIMESTAMP` 函数使用方法和示。 ### 1. 基本用法 `UNIX_TIMESTAMP()` 函数可以不带参数调用,也可以带一个日期时间表达式作为参数。 - **不带参数**:返回当前的日期和时间对应的 UNIX 时间戳。 ```sql SELECT UNIX_TIMESTAMP(); -- 示输出:1717556400 (对应 2024-06-06 12:00:00 UTC) ``` - **带日期时间参数**:将指定的日期时间值转换为 UNIX 时间戳。 ```sql SELECT UNIX_TIMESTAMP('2024-06-06 12:00:00'); -- 示输出:1717556400 ``` ### 2. 与 `FROM_UNIXTIME()` 的区别 `UNIX_TIMESTAMP()` 和 `FROM_UNIXTIME()` 是互为逆操作的函数: - `UNIX_TIMESTAMP()` 将日期时间转换为 UNIX 时间戳(整数)。 - `FROM_UNIXTIME()` 将 UNIX 时间戳转换为日期时间格式。 ```sql SELECT UNIX_TIMESTAMP('2024-06-06 12:00:00'); -- 输出:1717556400 SELECT FROM_UNIXTIME(1717556400); -- 输出:'2024-06-06 12:00:00' ``` ### 3. 处理 TIMESTAMP 列 在 MySQL 中,`TIMESTAMP` 类型的数据存储为内部的 32 位整数,表示 UNIX 时间戳,但查询时通常以格式化的日期时间字符串返回。如果需要对 `TIMESTAMP` 列进行基于秒级的操作,可以使用 `UNIX_TIMESTAMP()` 函数获取其原始的整数值。 ```sql SELECT UNIX_TIMESTAMP(created_at) AS unix_time FROM users; ``` ### 4. 与其他时间函数的配合使用 `UNIX_TIMESTAMP()` 可以与 `TIMESTAMPDIFF()`、`TIMESTAMPADD()` 等函数结合使用,实现更复杂的时间计算。 - **计算两个日期之间的秒数差** ```sql SELECT TIMESTAMPDIFF(SECOND, '2024-06-01', '2024-06-06'); -- 输出:432000 (即 5 天 × 24 小时 × 60 分钟 × 60 秒) ``` - **添加指定时间单位到时间戳** ```sql SELECT FROM_UNIXTIME(TIMESTAMPADD(SECOND, 3600, UNIX_TIMESTAMP('2024-06-06 12:00:00'))); -- 输出:'2024-06-06 13:00:00' ``` ### 5. 注意事项 - `UNIX_TIMESTAMP()` 返回的是秒级时间戳,不包含毫秒。 - 如果传入的日期时间值为 `NULL`,则返回 `NULL`。 - `UNIX_TIMESTAMP()` 支持的日期范围为 '1970-01-01 00:00:01' UTC 到 '2038-01-19 03:14:07' UTC,超出此范围的日期会导致错误或返回 `NULL`。 ### 6. 应用场景 - **时间比较**:将日期时间转换为整数后,便于进行大小比较。 - **性能优化**:在索引列上使用 `UNIX_TIMESTAMP()` 可以避免对日期格式进行解析,提高查询效率。 - **日志分析**:处理日志中以时间戳形式记录的事件,便于按时间窗口进行统计。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值