练习时执行一条修改数据库连接数的语句: alter system set processes=1 scope=spfile;

然后关闭数据库: shutdown

再启动数据库时,出现异常,报错信息如下:

ORA-00824:cannot set SGA_TARGET or MEMORY_TARGET due to existing internal settings-LMLPHP

报错的意思是说:参数文件(spfile)中的db_block_buffers参数设置的与SGA_TARGET或MEMORY_TARGET有冲突

错误分析:参数文件中的参数值设置的有问题

尝试解决:

(1)通过启动数据库并且指定pfile方式启动,即:startup pfile='E:\app\zhaoqx\product\11.2.0\dbhome_1\dbs\init.ora'

思路是正确的,但是指定的init.ora文件是错误的,应该指定路径为:E:\app\zhaoqx\admin\dbora\pfile\init.ora.521201614839的参数文件

正确的执行语句: startup pfile='E:\app\zhaoqx\admin\dbora\pfile\init.ora.521201614839'

ORA-00824:cannot set SGA_TARGET or MEMORY_TARGET due to existing internal settings-LMLPHP

(2)虽然根据上面的指定pfile启动方式可以将数据库正确启动,但是下一次不指定pfile的话,还是会报错(因为按照读取参数文件顺序:spfile --> pfile --> init.ora)

所以考虑到以后数据库启动时不用再指定pfile文件,即执行以下语句,将通过init.ora文件创建spfile.ora文件

create spfile='d:\spfiledbora.ora' from pfile='E:\app\zhaoqx\admin\dbora\pfile\init.ora.521201614839' ;

ORA-00824:cannot set SGA_TARGET or MEMORY_TARGET due to existing internal settings-LMLPHP

(3)最后将新生成的spfile.ora文件,复制到数据库寻找的默认路径下,即:E:\app\zhaoqx\product\11.2.0\dbhome_1\database路径下

ORA-00824:cannot set SGA_TARGET or MEMORY_TARGET due to existing internal settings-LMLPHP

05-08 07:51