oracle linux 修改字符集

  1. select userenv('language') from dual; //查看系统字符集编码
  2. select * from nls_database_parameters where parameter in ('NLS_CHARCTERSET','NLS_NCHAR_CHARACTERSET');
  3. shutdown immediate
  4. startup
  5. alter session set sql_trace=true;
  6. alter system enable restricted session;
  7. show parameter job_queue_processes;
  8. alter system set job_queue_processes=0;
  9. alter system set aq_tm_processes=0;
  10. alter database character set INTERNAL_USE AL32UTF8;
  11. update props$ set VALUE$='UTF8' where NAME='NLS_NCHAR_CHARACTERSET';

 

 

数据导入时报ORA-12899错误,即插入的数据长度超出字段的设置长度,实际长度并不长,这是由于Oracle字符集不同,汉字占的长度不同造成的。中文在ZHS16GBK中占2个字节,在UTF-8中却占3个字节,所以汉字导入UTF-8字符集的数据库就很容易出现字段长度不够,解决办法,一个是增加字段长度,还有就是修改字符集。

如果系统中已经存在很多数据,建议修改字段长度,因为修改字符集后原来数据库表中的汉字全部变成乱码。如果一定要修改字符集,必须先导出数据,待到字符集修改后再重新导入这些数据。

查看字符集的方法可以用PL/SQL DEVELOP ---->Reports---->DBA---->NLS Database Parameters,结果如下图:

如上图所示,字符集是UTF-8,修改字符集的方法如下:

修改数据库字符集为:ZHS16GBK
查看服务器端字符集SQL > select * from V$NLS_PARAMETERS
Telnet到服务器,执行:$sqlplus /nolog
SQL>conn / as sysdba
若此时数据库服务器已启动,则先执行 SHUTDOWN IMMEDIATE 命令关闭数据库服务器,
然后执行以下命令:
SQL>shutdown immediate
SQL>STARTUP MOUNT
SQL>ALTER SYSTEM ENABLE RESTRICTED SESSION;
SQL>ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;
SQL>ALTER SYSTEM SET AQ_TM_PROCESSES=0;
SQL>ALTER DATABASE OPEN;
SQL>ALTER DATABASE CHARACTER SET ZHS16GBK;
ERROR at line 1:ORA-12721: operation cannot execute when other sessions are active
若出现上面的错误,使用下面的办法进行修改,使用INTERNAL_USE可以跳过超集的检查:
SQL>ALTER DATABASE CHARACTER SET INTERNAL_USE ZHS16GBK;
SQL>SHUTDOWN IMMEDIATE
SQL>STARTUP

至此,字符集修改完毕,再查字符集,结果如下:

 

 

 

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要查看Oracle数据库的字符集,可以使用以下方法: 1. 通过查询NLS_DATABASE_PARAMETERS视图:在Oracle数据库中,可以使用以下SQL查询来查看数据库的字符集: SELECT parameter, value FROM NLS_DATABASE_PARAMETERS WHERE parameter LIKE 'NLS_%CHARACTERSET'; 这将返回数据库的字符集参数和对应的值。 2. 通过查看数据库导出文件的字符集信息:如果你有一个包含字符集信息的数据库导出文件(.dmp文件),你可以使用UltraEdit等文本编辑器打开该文件,并以16进制方式查看第2个和第3个字节的内容。这些字节记录了导出文件的字符集信息。然后,你可以使用对应的SQL查询来确定字符集。例如,如果第2个和第3个字节的内容是0354,你可以查询相应的字符集。 3. 通过查询NLS_LANG环境变量:在Unix/Linux操作系统中,可以使用以下命令查询NLS_LANG环境变量的值: echo $NLS_LANG 这将返回形如"AMERICAN_AMERICA.AL32UTF8"的值,其中.AL32UTF8表示数据库的字符集。 如果发现数据库服务器端与客户端的字符集不一致,应该统一修改为与服务器端相同的字符集,以确保数据的正确传输和处理。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [ORACLE 查看数据库字符集](https://blog.csdn.net/PeterJin/article/details/104605799)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [如何查看oracle数据库字符集](https://blog.csdn.net/liaoyuanzi/article/details/7702749)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值