- 1、本文档共2页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
oracle 修改数据库的字符集编码为UTF 1、查看数据库字符集?
数据库服务器字符集:select * from nls_database_parameters,其来源于 props$,是表示数据库的字符集。
客户端字符集环境:select * from nls_instance_parameters,其来源于 v$parameter,表示客户端的字符集的设置,可能是参数文件,环境变量或者是注册表会话字符集环境 select
* from nls_session_parameters,其来源于 v$nls_parameters,表示会话自己的设置,可能是会话的环境变量或者是 alter session 完成,如果会话没有特殊的设置,将与nls_instance_parameters 一致。
客户端的字符集要求与服务器一致,才能正确显示数据库的非 Ascii 字符。如果多个设置存在的时候,alter session环境变量注册表参数文件字符集要求一致,但是语言设置却可以不同, 语言设置建议用英文。 如字符集是 zhs16gbk , 则 nls_lang 可以是American_America.zhs16gbk。
2、修改Oracle 的字符集,如下例把字符集GB2312 修改为UTF-8 步骤:
在 SQL*PLUS 中,以DBA 登录conn 用户名 as sysdba
执行转换语句: SHUTDOWN IMMEDIATE; STARTUP MOUNT EXCLUSIVE;
ALTER SYSTEM ENABLE RESTRICTED SESSION; ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0; ALTER SYSTEM SET AQ_TM_PROCESSES=0; ALTER DATABASE OPEN;
ALTER DATABASE NATIONAL CHARACTER SET UTF8; SHUTDOWN IMMEDIATE;
STARTUP;
注意:如果没有大对象,在使用过程中进行语言转换没有什么影响,(切记设定的字符集必须是 ORACLE 支持,不然不能start)
按上面的做法就可以,但是可能会出现
ORA-12717: Cannot ALTER DATABASE NATIONAL CHARACTER SET when NCLOB data exists ORA-12717: 存在 NCLOB, NCHAR 或 NVARCHAR2 数据时, 不能发出 ALTER DATABASE NATIONAL CHARACTER SET 命令
这样的提示信息
要解决这个问题有两种方法
一个是 , 利用 INTERNAL_USE 关键字修改区域设置 , 还有一个是利用 re-create,但是re-create 有点复杂,所以请用internal_use,
SHUTDOWN IMMEDIATE; STARTUP MOUNT EXCLUSIVE;
ALTER SYSTEM ENABLE RESTRICTED SESSION; ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0; ALTER SYSTEM SET AQ_TM_PROCESSES=0; ALTER DATABASE OPEN;
ALTER DATABASE NATIONAL CHARACTER SET INTERNAL_USE UTF8;
SHUTDOWN IMMEDIATE;
STARTUP;
如果按上面的做法做,National charset 的区域设置就没有问题 。
文档评论(0)