oracle中的varchar2


  今天做项目时候保存中文的时候出现错误:


javax.servlet.ServletException: (HibernateTemplate): encountered SQLException [ORA-12899: "XX_XX_TEST"."TB_CNB_INDIACCOUNT"."C_ACCOUNT" 的值太大 (实际值: 50, 最大值: 36)

]; nested exception is java.sql.BatchUpdateException: ORA-12899: "XX_XX_TEST"."TB_CNB_INDIACCOUNT"."C_ACCOUNT" 的值太大 (实际值: 50, 最大值: 36)

 

  查了一下数据库中的表对应字段为 varchar2(36),最大长度为36个字符,换成unicode的java汉字就是2个字节对应一个汉字,最多能存18个汉字,因此报错,需要修改varchar2的长度。

1.varchar2把所有字符都占两字节处理(一般情况下),varchar只对汉字和全角等字符占两字节,数字,英文字符等都是一个字节;

2.VARCHAR2把空串等同于null处理,而varchar仍按照空串处理;
3.VARCHAR2字符要用几个字节存储,要看数据库使用的字符集,大部分情况下建议使用varchar2类型,可以保证更好的兼容性。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值