今天做项目时候保存中文的时候出现错误:
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只对汉字和全角等字符占两字节,数字,英文字符等都是一个字节;
本文介绍了在项目中遇到的数据库字段长度限制问题,详细解释了由于字段设置不当导致的错误原因,并给出了调整字段长度的具体解决方案。
480

被折叠的 条评论
为什么被折叠?



