鱼悠奕 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 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效