MySQL 随机日期/时间生成

MySQL 随机日期/时间生成

  1. 生成24小时内时间:有微秒值
sql 复制代码
mysql> select sec_to_time(rand() * 86400);
+-----------------------------+
| sec_to_time(rand() * 86400) |
+-----------------------------+
| 21:56:22.705685             |
+-----------------------------+
1 row in set (0.00 sec)

2.生成一天内随机时间

sql 复制代码
mysql> select sec_to_time(floor(rand() * 86400));
+------------------------------------+
| sec_to_time(floor(rand() * 86400)) |
+------------------------------------+
| 08:44:18                           |
+------------------------------------+
1 row in set (0.00 sec)

3.生成1小时内时间:包括微秒

sql 复制代码
mysql> select sec_to_time(rand() * 3600);
+----------------------------+
| sec_to_time(rand() * 3600) |
+----------------------------+
| 00:04:40.939843            |
+----------------------------+
1 row in set (0.00 sec)

4.生成比当前时间小的90天内的随机日期:精确到天,注意负号 -90

sql 复制代码
mysql> SELECT date_add(current_date, interval rand() * -90 day) rand_date;
+------------+
| rand_date  |
+------------+
| 2023-10-14 |
+------------+
1 row in set (0.00 sec)

5.生成比当前时间大的90天内的随机日期:精确到天

sql 复制代码
mysql> SELECT date_add(current_date, interval rand() * 90 day) rand_date;
+------------+
| rand_date  |
+------------+
| 2023-12-03 |
+------------+
1 row in set (0.00 sec)

6.生成比当前时间小的90天内的随机时间:显示到秒实际精确到天

sql 复制代码
mysql> SELECT date_add(NOW(), interval rand() * -90 day) rand_date;
+---------------------+
| rand_date           |
+---------------------+
| 2023-10-07 11:06:14 |
+---------------------+
1 row in set (0.00 sec)

7.生成比当前时间小的90天内的随机时间:精确到微秒 90*24*3600 = 7776000 ,90天的总秒数。

sql 复制代码
mysql> SELECT date_add(current_timestamp, interval rand() * -7776000 second);
+----------------------------------------------------------------+
| date_add(current_timestamp, interval rand() * -7776000 second) |
+----------------------------------------------------------------+
| 2023-10-27 23:40:25.021294                                     |
+----------------------------------------------------------------+
1 row in set (0.00 sec)

8.生成比当前时间小的90天内的随机时间:精确到秒,格式化

sql 复制代码
mysql> SELECT DATE_FORMAT(date_add(current_timestamp, interval rand() * -7776000 second),'%Y-%m-%d %H:%i:%s');
+-------------------------------------------------------------------------------------------------+
| DATE_FORMAT(date_add(current_timestamp, interval rand() * -7776000 second),'%Y-%m-%d %H:%i:%s') |
+-------------------------------------------------------------------------------------------------+
| 2023-09-17 12:52:17                                                                             |
+-------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

--方法2:
select concat(date_add(current_date(),interval rand()*-90 day),' ',sec_to_time(floor(rand()*86400)))

总结:是用date_add()或者date_sub()方法,结合rand()方法进行随机谁的取值,从而实现随机取时间

参考:

1、https://blog.csdn.net/qq_39065491/article/details/134328488

相关推荐
WangYaolove131410 分钟前
基于python的在线水果销售系统(源码+文档)
python·mysql·django·毕业设计·源码
山岚的运维笔记33 分钟前
SQL Server笔记 -- 第18章:Views
数据库·笔记·sql·microsoft·sqlserver
roman_日积跬步-终至千里1 小时前
【LangGraph4j】LangGraph4j 核心概念与图编排原理
java·服务器·数据库
汇智信科1 小时前
打破信息孤岛,重构企业效率:汇智信科企业信息系统一体化运营平台
数据库·重构
野犬寒鸦2 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
霖霖总总2 小时前
[小技巧66]当自增主键耗尽:MySQL 主键溢出问题深度解析与雪花算法替代方案
mysql·算法
晚霞的不甘3 小时前
揭秘 CANN 内存管理:如何让大模型在小设备上“轻装上阵”?
前端·数据库·经验分享·flutter·3d
市场部需要一个软件开发岗位3 小时前
JAVA开发常见安全问题:纵向越权
java·数据库·安全
海奥华23 小时前
mysql索引
数据库·mysql
2601_949593654 小时前
深入解析CANN-acl应用层接口:构建高效的AI应用开发框架
数据库·人工智能