oracle06553,ora-06552,ora-06553的错误

今天打开plsql 进去 table 报错 “ora-06552 pl…,ora-06553 plsql    ”,无法查看表内容了,原来是我昨天更新了 “update   props$   set   value$=’ZHS16GBK’

where   name=’NLS_CHARACTERSET’;

update   props$   set   value$=’ZHS16GBK’

where     name=’NLS_NCHAR_CHARACTERSET’;“

首先,确认字符集是否修改的不彻底。

SELECT DISTINCT (NLS_CHARSET_NAME(CHARSETID)) CHARACTERSET,

DECODE(TYPE#, 1,

DECODE(CHARSETFORM, 1, ‘VARCHAR2’, 2, ‘NVARCHAR2’, ‘UNKOWN’),

9,

DECODE(CHARSETFORM, 1, ‘VARCHAR’, 2, ‘NCHAR VARYING’, ‘UNKOWN’),

96,

DECODE(CHARSETFORM, 1, ‘CHAR’, 2, ‘NCHAR’, ‘UNKOWN’),

112,

DECODE(CHARSETFORM, 1, ‘CLOB’, 2, ‘NCLOB’, ‘UNKOWN’)) TYPES_USED_IN

FROM SYS.COL$

WHERE CHARSETFORM IN (1, 2)

AND TYPE# IN (1, 9, 96, 112);

如果上面的查询的确显示有多个字符集的设定,则进行如下处理:SHUTDOWN IMMEDIATE;

STARTUP MOUNT;

ALTER SYSTEM ENABLE RESTRICTED SESSION;

ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;

ALTER SYSTEM SET AQ_TM_PROCESSES=0;

ALTER DATABASE OPEN;

COL VALUE NEW_VALUE CHARSET

SELECT VALUE FROM NLS_DATABASE_PARAMETERS WHERE PARAMETER=’NLS_CHARACTERSET’;

COL VALUE NEW_VALUE NCHARSET

SELECT VALUE FROM NLS_DATABASE_PARAMETERS WHERE PARAMETER=’NLS_NCHAR_CHARACTERSET’;

–INTERNAL_USE是没有写在文档中的参数,用以强制完成字符集一致化

ALTER DATABASE CHARACTER SET INTERNAL_USE &CHARSET;

ALTER DATABASE NATIONAL CHARACTER SET INTERNAL_USE &NCHARSET;

SHUTDOWN IMMEDIATE;

STARTUP;

— 再次启动数据库一遍

SHUTDOWN IMMEDIATE;

STARTUP;

注意:修改字符集只是修改了数据字典,并没有对数据进行字符集转换!

赞过:

赞 正在加载……

相关

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值