阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Oracle的FIXED_DATE参数

133次阅读
没有评论

共计 1376 个字符,预计需要花费 4 分钟才能阅读完成。

今天发现一个有意思的问题,我们知道,在 Oracle 数据库中正常执行 select sysdate from dual 都可以返回当前主机的系统时间。
正常修改系统时间,对应的查询结果也会变成修改后的系统时间。
现在遇到一个问题:测试系统修改了主机系统时间,数据库查询 select sysdate from dual 返回的时间和所在系统的主机时间相差很大,进一步排查发现返回的时间是固定不变的。
最终发现是 Oracle 有参数可以使得 sysdate 一直返回固定的时间,供某些测试场景使用。该库也是因为有其他测试人员设置了该参数,而其他测试人员不知道,产生了疑惑。

官方对这个参数的描述如下:

FIXED_DATE enables you to set a constant date that SYSDATE will always return instead of the current date. To undo a fixed date setting, specify FIXED_DATE=NONE. This parameter is useful primarily for testing. The value can be in the format shown above or in the default Oracle date format, without a time.

简单试验验证下,的确如此:

--1. 设定会话时间显示格式:
SQL> alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss';

Session altered.

--2. 查询 sysdate 值,是正常返回数据库所在主机的系统时间:
SQL>
SQL> select sysdate from dual;

SYSDATE
-------------------
2017-03-31 10:16:10

SQL> /

SYSDATE
-------------------
2017-03-31 10:16:18

--3. 设置 fixed_date 参数为固定一个值:
SQL> alter system set fixed_date = '2017-04-01 12:00:00';

System altered.

--4. 再次查询发现 sysdate 时间为设置的值,且固定不变:
SQL> select sysdate from dual;

SYSDATE
-------------------
2017-04-01 12:00:00

SQL> /

SYSDATE
-------------------
2017-04-01 12:00:00

--5. 设置 fixed_date 参数为 none,使 sysdate 正常显示所在主机的系统时间:
SQL> alter system set fixed_date = none;

System altered.

SQL> select sysdate from dual;

SYSDATE
-------------------
2017-03-31 10:20:11

SQL> /

SYSDATE
-------------------
2017-03-31 10:20:14

SQL>

更多 Oracle 相关信息见 Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12

本文永久更新链接地址 :http://www.linuxidc.com/Linux/2017-04/143141.htm

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计1376字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中