如何在 MySQL 中将 CURRENT_TIMESTAMP 临时更改为另一个时间

hel*_*rry 3 mysql

我有一个相当大且复杂的 mysql 查询来进行黑盒测试,这个查询对时间敏感,它有很多基于current_timestamp.

我的目标是进行一些测试,使其始终通过或失败。我正在考虑current_timestamp在运行查询之前将临时值模拟为固定日期,并在查询后将其设置回原始值。

这是可行的吗?

我无法修改查询本身(即:找到将 current_timestamp 替换为其他内容)

谢谢

Dyl*_* Su 5

通过设置系统变量“时间戳”。要再次将其恢复为当前时间戳,请将其设置为 DEFAULT。

mysql> SET TIMESTAMP = UNIX_TIMESTAMP('2015-01-01');
Query OK, 0 rows affected (0.00 sec)

mysql> SELECT NOW();
+---------------------+
| NOW()               |
+---------------------+
| 2015-01-01 00:00:00 |
+---------------------+
1 row in set (0.00 sec)

mysql> SET TIMESTAMP = DEFAULT;
Query OK, 0 rows affected (0.00 sec)

mysql> SELECT NOW();
+---------------------+
| NOW()               |
+---------------------+
| 2016-03-08 09:50:16 |
+---------------------+
1 row in set (0.00 sec)
Run Code Online (Sandbox Code Playgroud)