我有一个相当大且复杂的 mysql 查询来进行黑盒测试,这个查询对时间敏感,它有很多基于current_timestamp.
我的目标是进行一些测试,使其始终通过或失败。我正在考虑current_timestamp在运行查询之前将临时值模拟为固定日期,并在查询后将其设置回原始值。
这是可行的吗?
我无法修改查询本身(即:找到将 current_timestamp 替换为其他内容)
谢谢
通过设置系统变量“时间戳”。要再次将其恢复为当前时间戳,请将其设置为 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)