20120410 创建数据库内存分配& ora-06502 &ora-22973

------------   20120410 创建数据库内存分配  begin  ---------

 

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.7GPGA+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

 

------------   20120410 创建数据库内存分配  end---------
 
---------     ORA-06502  begin -------------

以上设置

数据库字符集: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

 

---------     ORA-06502  end-------------
 
 
------- 修改 出现   ORA-01450 超出最大关键字长度(2395)  ---------
 

数据库字符集:AL32UTF8

国家字符集:UTF8

NLS_LENGTH_SEMANTICS=CHAR

出现错误   ORA-01450 超出最大关键字长度(2395)
原来数据库块 6144              
排序区  524288
 
 2395/6144=38%   
 
修改方法 :  http://blog.itpub.net/post/468/68512  通常可以达到80%左右
 
处理 :
改回来
 

数据库字符集:ZHSGBK32

国家字符集:AL16UTF16

NLS_LENGTH_SEMANTICS=CHAR

可以考虑调整数据块为  8k   8192

可以排序区 为   640K

 
 
------- 修改 出现   ORA-01450 超出最大关键字长度(2395)  ---------

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值