oracle中varchar2(2)存不了一个汉字的原因


错误提示:

一个汉字占了三个字节,而不是两个,这跟字符集有关。

查一下字符集:select userenv('language') from dual; 

  结果显示,本机Oracle的字符集是UTF-8,32位,而不是GBK的16位。UTF-8的每个字符占3个字节(bytes),可以通过修改默认字符集来实现varchar2(2)存储一个汉字。

若此时数据库服务器已启动,则先执行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 INTERNAL_USE ZHS16GBK; //跳过超子集检测
 
SQL>ALTER DATABASE national CHARACTER SET INTERNAL ZHS16GBK;

SQL>SHUTDOWN IMMEDIATE;
 
SQL>STARTUP

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM