Oracle中NVARCHAR2字符集不匹配问题

   Oracle中在做字符匹配时 遇到 NVARCHAR2 类型时报错,提示 字符集不匹配。

对使用 NVARCHAR2 的地方,需要对字段进行字符转换,加上 to_char(nvarchar2 字段) 即可。

 

   例如:

   SELECT substr(bm.matnr, 3) wlbm, ms.maktx wlms, bm.meins jldw, bm.matkl wlz
 , bm.normt gybzms,bm.laeda gxsj,(case to_char(trim(bm.lvorm)) when 'X' then '0' else '1' end) WLZT
   FROM makt ms, mara bm
  WHERE ms.matnr = bm.matnr;

 

   VARCHAR2是Oracle提供的特定数据类型,Oracle可以保证VARCHAR2在任何版本中该数据类型都可以向上和向下兼容。

   VARCHAR在Oracle中不建议使用。

 

   NVARCHAR2和VARCHAR2的区别:

   从使用角度来看区别在于:NVARCHAR2在计算长度时和字符集相关的,例如数据库是中文字符集时以长度10为例,则

   1、NVARCHAR2(10)是可以存进去10个汉字的,如果用来存英文也只能存10个字符。

   2、而VARCHAR2(10)的话,则只能存进5个汉字,英文则可以存10个。 

转载于:https://www.cnblogs.com/zxpsl/p/4993009.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值