1、9I安装的时候默认值为
共享池: 48MB
缓冲区高速缓存:24MB
JAVA池:32M
大型池:8
PGA:24
合计为176MB
2\9I 安装的时候调整为100%
用于ORACLE的物理内存为(2047MB)的百分比
当百分率为100的时候
共享池: 333MB
缓冲区高速缓存:1000MB
JAVA池:32M
大型池:197
PGA:444
合计为2046MB
3、自定义分配
IDEACENTER K330 物理内存 2.99GB
3.1 根据分配原则
SGA不超过1.7G,PGA+SGA不超过2G
shared_pool_size 200M--300M
log_buffer : 128K ---- 1M
large_pool_size 10M --- 50M
java_pool_size 30M
data buffer ,在做了前面的设置后,凡可以提供给oracle的内存
PGA : =(total_mem * 80%) * 20% (这里的total_mem为机器的内存 total_mem * 80%=分配给ORACLE的内存=2046) 计算所得409
3.2 实际分配
3.2.1 SGA
shared_pool_size 分配250
large_pool_size 分配 50
java_pool_size 分配 32
data buffer 分配 1200 mb
3.2.2
PGA : 分配444
以上合计为 2016
数据库字符集:ZHSGBK32
国家字符集:AL16UTF16
NLS_LENGTH_SEMANTICS=CHAR
以上设置
数据库字符集:ZHSGBK32
国家字符集:AL16UTF16
NLS_LENGTH_SEMANTICS=CHAR
但是出现如下错误:
ORA-06502 PL/SQL Numeric or value error
原因:有一天你把BYTE改成了CHAR,然后去调用该存储过程,你会发现报 ORA-06502 PL/SQL Numeric or value error错误,因为虽然环境使用的是CHAR语义,
但是存储过程里还是使用的BYTE语义,此时你需要重要编译该存储过程,它后重新读取当前SESSION的值,写入代码中。
处理:
1、
数据库字符集:AL32UTF8
国家字符集:UTF8
2、忽略问题,然后用PL/SQL 工具重新编译无效的存储过程
3、备注
数据库字符集在创建数据库时指定,在创建后通常不能更改。在创建数据库时,可以指定字符集(CHARACTER SET)和国家字符集(NATIONAL CHARACTER SET)。
<st1:chsdate year="1899" month="12" day="30" islunardate="False" isrocdate="False" w:st="on">2.4.1</st1:chsdate>
数据库字符集
(1)用来存储CHAR, VARCHAR2, CLOB, LONG等类型数据
(2)用来标示诸如表名、列名以及PL/SQL变量等
(3)用来存储SQL和PL/SQL程序单元等
国家字符集:
(1)用以存储NCHAR, NVARCHAR2, NCLOB等类型数据
(2)国家字符集实质上是为oracle选择的附加字符集,主要作用是为了增强oracle的字符处理能力,因为NCHAR数据类型可以提供对亚洲使用定长多字节编码的支持,而数据库字符集则不能。国家字符集在oracle9i中进行了重新定义,只能在unicode编码中的AF16UTF16和UTF8中选择,默认值是AF16UTF16
数据库字符集:AL32UTF8
国家字符集:UTF8
NLS_LENGTH_SEMANTICS=CHAR
数据库字符集:ZHSGBK32
国家字符集:AL16UTF16
NLS_LENGTH_SEMANTICS=CHAR
可以考虑调整数据块为 8k 8192
可以排序区 为 640K