鱼悠奕 2021-09-01 11:14 采纳率: 58.3%
浏览 29
已结题

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字节编码的话,和上述问题是冲突的
请不吝赐教!!

  • 写回答

2条回答 默认 最新

  • 唯一的小彬哥 2021-09-18 09:36
    关注

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 9月30日
  • 已采纳回答 9月22日
  • 创建了问题 9月1日

悬赏问题

  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3
  • ¥15 牛顿斯科特系数表表示
  • ¥15 arduino 步进电机
  • ¥20 程序进入HardFault_Handler
  • ¥15 关于#python#的问题:自动化测试