oracle数据库,varchar2(10)只能存储两个汉字??

oracle11g

 ---查看数据库字符集 
 SELECT * FROM v$nls_parameters WHERE PARAMETER='NLS_CHARACTERSET';--ZHS16GBK
 ---查看指定表的字符集
 select distinct(userenv('language')) from emp;--AMERICAN_AMERICA.ZHS16GBK

网上说ZHS16GBK是2字节编码
那么varcha2(10)应该最多可以存储5个汉字

select e.ename,
case e.ename
  when '00000' then '你好'
    when 'wertt'  then '世界'
      when 'vvv' then '好可爱'
        else '无名氏'
          end
 from emp e;

问题一:执行上述操作时,只能看到两个汉字

img

问题二:图形化界面新增记录,ename最多输入三个汉字
想输入:唐老鸭呀,四个汉字,标红
输入:唐老鸭,就没有问题

img

只能想到是字符集的问题
但是2字节编码的话,和上述问题是冲突的
请不吝赐教!!

你要明白VARCAHR2(10) 定义可以有两种修饰符一种叫字节,一种叫代码点。如果你使用代码点那么VARCAHR2(10) 能存10个汉字,如果用字节则可能可以存2~5个汉字。

贴你insert values 的执行报错结果
无论哪种编码,varchar2(10)都会只存两个汉字,又不是生僻字。