如何暂时将CURRENT_TIMESTAMP更改为MySQL中的另一个时间

时间:2016-03-07 15:27:52

标签: mysql

我对blackbox测试有一个相当大而复杂的mysql查询,这个查询是时间敏感的,它有很多基于current_timestamp的条件。

我的目标是进行一些测试,以便它总是通过或失败。我想在运行查询之前暂时将current_timestamp的值模拟到固定日期,并在查询后将其设置回原始值。

这是可行的吗?

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

由于

1 个答案:

答案 0 :(得分:2)

通过设置系统变量' 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)