Chinaunix首页 | 论坛 | 博客
  • 博客访问: 8236743
  • 博文数量: 444
  • 博客积分: 10593
  • 博客等级: 上将
  • 技术积分: 3852
  • 用 户 组: 普通用户
  • 注册时间: 2006-05-09 15:26
文章分类

全部博文(444)

文章存档

2014年(1)

2013年(10)

2012年(18)

2011年(35)

2010年(125)

2009年(108)

2008年(52)

2007年(72)

2006年(23)

分类: Oracle

2009-03-31 16:21:39

如何解决Oracle数据库中汉字长度的问题

 

问题:
varchar2(4000) abc;intert into table_name(abc) values('这里有1500个汉字……');
报错:插入字符过长!经过测试,发现一个汉字占3个字节,所以会报错。 问题症结: 使用的字符集是UTF8,就会出现此错误! 你可以使用命令查看:
SQL> select * from v$nls_parameters where parameter='NLS_CHARACTERSET'ARAMETER------------------------------------------------VALUE------------------------------------------------NLS_CHARACTERSETAL32UTF8
解决方法: 建议使用ZHS16GBK字符集! 执行此操作后,问题即可得以解决。

SQL> SHUTDOWN IMMEDIATE;  

SQL> STARTUP MOUNT;

SQL> ALTER SYSTEM ENABLE RESTRICTED SESSION; SQL> ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0; SQL> ALTER DATABASE OPEN;

SQL> ALTER DATABASE CHARACTER SET 2UTF8/ZHS16GBK;

SQL> SHUTDOWN IMMEDIATE;

SQL> STARTUP;


阅读(2987) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~