oracle数据库的初始化参数,主要来源于两个Oracle内部数据字典表X$KSPI和X$KSPPCV;
通常我们查询的V$Parameter视图或使用show parameter命令都是就来源于这两个系统表的,但通过这两种方式不能查询隐含参数。
X$KSPPCV用以记录当前的设置的值,及是否使用了缺省值等信息,X$KSPPI则是一个基础表,用于记录参数名、参数说明等简单的信息。
X$KSPPI
ADDR RAW(4) –内存地址
INDX NUMBER –序号,从0开始
INST_ID NUMBER
KSPPINM VARCHAR2(64) –参数名称
KSPPITY NUMBER
KSPPDESC VARCHAR2(64) –描述
KSPPIFLG NUMBER
X$KSPPCV
ADDR RAW(4) –内存地址
INDX NUMBER –序号,从0开始
INST_ID NUMBER –instance number
KSPPSTVL VARCHAR2(512) –当前值
KSPPSTDF VARCHAR2(9) –缺省值
KSPPSTVF NUMBER –标志字段,用来说明(‘Modified’or ‘System Modified’ or is_adjusted)
KSPPSTCMNT VARCHAR2(255) –comment
查看参数基本信息
select nam.indx + 1numb,
nam.ksppinm name,
val.ksppstvl value,
nam.ksppity type,
val.ksppstdf is_default,
decode(bitand(nam.ksppiflg / 256, 1), 1, 'True', 'False') is_session_modifiable,
decode(bitand(nam.ksppiflg / 65536, 3),
1,
'Immediate',
2,
'Deferred',
3,
'Immediate',
'False') is_system_modifiable,
decode(bitand(val.ksppstvf, 7),
1,
'Modified',
4,
'System Modified',
'False') is_modified,
decode(bitand(val.ksppstvf, 2), 2, 'True', 'False') is_adjusted,
nam.ksppdesc description
from x$ksppi nam
inner join x$ksppcv val
on nam.indx = val.indx;
Oracle数据库的初始化参数不仅可以通过V$Parameter视图或show parameter命令查询,还包含隐含参数。$ksppi和x$ksppcv是两个重要的内部数据字典表,它们分别记录参数的基础信息和当前设置值。$ksppi存储参数名称、描述等,而x$ksppcv包含当前值、缺省值和状态信息。通过这些表,可以深入理解Oracle数据库参数的工作原理。
1132

被折叠的 条评论
为什么被折叠?



