oracle 9i spfile(sytem parameter file)的特性及修改注意事项

本文介绍了判断Oracle数据库是用spfile还是pfile启动的方法,通过特定SQL查询结果判断。还说明了pfile和spfile的修改方式,pfile可直接编辑重启,spfile修改较复杂。此外,阐述了Oracle查找SPFILE或读取init.ora的顺序。
之前的oracle8.1.7用的是pfile倒是觉得很方便的,可是到了oracle9i就变了,变成spfile了,所以就有了下面的内容:[@more@]pfile之所以有点不方便的地方是每次的修改只能再restart后才能生效,而spfile可是直接修改后马上生效,不过还是只是一部分参数修改可以做到不restart database 照样有的参数修改的时候也需要restart后才能生效。所以我不是很喜欢用spfile也有一个原因他给了我很多不方便的地方,还是写写我对这个参数的理解吧。

1,要知道你得database 是用spfile 启动的还是pfile启动的,可以用下面的方法判断:

SQL> SELECT name,value FROM v$parameter WHERE name='spfile';

NAME
------------------------------------------------------------------
VALUE
------------------------------------------------------------------
spfile
%ORACLE_HOME%DATABASESPFILE%ORACLE_SID%.OR

或者,

SQL> SHOW PARAMETER spfile

NAME TYPE
------------------------------------ ----------------------
VALUE
------------------------------
spfile string
%ORACLE_HOME%DATABASESPFILE%
ORACLE_SID%.OR

如果以上查询返回的value为空值则为pfile启动,如果有值则为spfile启动,如例为spfile启动。

2,pfile是文本格式的,如果需要修改的話直接編輯這個pfile後restart oracle 就可以了,可是spfile 則是二進制格式,他的修改就變的比較麻煩了,一種辦法是先create pfile='d:oracleadminpfileinitest.ora' from spfile.然後直接編輯initest.ora 完成後startup pfile='d:oracleadmininitest.ora'再create spfile='d:oracleora92databaseinitspfile.ora' from pfile='d:oracleadmininitest.ora',再startup 另一種修改的方法就是alter system set parameter =*** scope=both or spfile or memory (分別表示:both是改變實例and spfile, spfile 是只改變spfile的設定,memory則是只改變當前實例,另外以上創建SPFILE需要SYSDBA或者SYSOPER的权限。 3,当使用不带pfile 子句的startup 命令时,Oracle 将从平台指定的默认位置上的服务器参数文件(SPFILE) 中读取初始化参数。Oracle查找SPFILE或者讀取init.ora的顺序是:在平台指定的默认位置上,Oracle首先查找名为spfile$ORACLE_SID.ora的文件,如果没有就查找spfile.ora文件,还没有的话,就找init$ORACLE_SID.ora文件。在$ORACLE_BASEadmindb_namepfile下,你很可能可以看到一个类似这样init.ora.192003215317]名字的文件,这就是初始化参数文件,只是跟上了时间戳。对于Oracle920,缺省的就使用spfile启动,但是这个spfile不是凭空而来,而是根据这个文件创建而来,你可以去掉这个长后缀,就是标准的pfile文件了。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/202861/viewspace-785114/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/202861/viewspace-785114/

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值