memory_target指定的值过小

当尝试启动Oracle数据库时遇到ORA-00838错误,原因是MEMORY_TARGET值小于SGA_TARGET和PGA_TARGET之和。在无法修改SPFILE的情况下,通过创建PFILE并增大MEMORY_TARGET值,然后启动实例和恢复为SPFILE模式,成功解决此问题。
摘要由CSDN通过智能技术生成

目录:

版本1

Oracle12c

版本2

 

版本3

 

关键字

修改占用内存

 

  1. 问题现象
    1. 在对Oracle服务所占内存进行修改后,重新使用cmd的管理员进行登录:

C:\Users\NsnServer>sqlplus 用户名/密码 as sysdba;

  1. 提示如下信息:

SQL*Plus: Release 12.1.0.2.0 Production on 星期一 12月 19 09:32:33 2016

Copyright (c) 1982, 2

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个错误是在使用 Oracle 数据库时出现的,它表示你尝试将 SGA_MAX_SIZE 参数设置为比 MEMORY_TARGET 参数更大的,这是不允许的。SGA_MAX_SIZE 是指定 SGA(System Global Area)最大大小的参数,而 MEMORY_TARGET指定 SGA 和 PGA(Process Global Area)总大小的参数。 在 Oracle 11g 及更高版本中,Oracle 推荐使用 MEMORY_TARGET 参数来管理 SGA 和 PGA 的大小,而不是手动设置 SGA_MAX_SIZE 和 PGA_AGGREGATE_TARGET 参数。这是因为使用 MEMORY_TARGET 可以更好地优化内存使用,提高系统性能。 因此,要解决这个错误,你需要调整 SGA_MAX_SIZE 和 MEMORY_TARGET 参数的,使它们保持一致或者 MEMORY_TARGET更大。你可以通过修改 Oracle 数据库的参数文件(init.ora 或 spfile)来更改这些参数的。具体操作步骤如下: 1. 使用 SQLPLUS 连接到 Oracle 数据库,以 SYSDBA 用户身份登录: ``` sqlplus / as sysdba ``` 2. 查看当前 SGA 和 PGA 的大小: ``` SHOW SGA; SHOW PARAMETER PGA_AGGREGATE_TARGET; ``` 3. 关闭数据库实例: ``` SHUTDOWN IMMEDIATE; ``` 4. 编辑参数文件(init.ora 或 spfile),将 MEMORY_TARGET 和 SGA_MAX_SIZE 参数设置为相同的,或者 MEMORY_TARGET更大。例如: ``` MEMORY_TARGET=3G SGA_MAX_SIZE=3G ``` 5. 启动数据库实例: ``` STARTUP ``` 6. 再次查看 SGA 和 PGA 的大小,确认修改成功: ``` SHOW SGA; SHOW PARAMETER PGA_AGGREGATE_TARGET; ``` 这样就可以避免 SGA_MAX_SIZE 和 MEMORY_TARGET 不一致的错误了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值